:root{color:#172033;font-synthesis:none;text-rendering:optimizelegibility;--background:#eef1f5;--surface:#fff;--surface-subtle:#f7f8fa;--text:#172033;--muted:#667085;--border:#d9dee8;--accent:#e86642;--accent-hover:#cf5231;--selection:#3478f6;--shadow:0 16px 48px #1720331a;background:#eef1f5;font-family:Inter,Prompt,Sarabun,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}[data-theme=dark]{color:#e2e8f0;--background:#0f1219;--surface:#1a1f2e;--surface-subtle:#232838;--text:#e2e8f0;--muted:#94a3b8;--border:#334155;--accent:#f97316;--accent-hover:#ea580c;--selection:#3b82f6;--shadow:0 16px 48px #0000004d;background:#0f1219}*{box-sizing:border-box}body{background:var(--background);min-width:320px;min-height:100vh;margin:0;transition:background-color .3s,color .3s}.skip-link{z-index:9999;background:var(--accent);color:#fff;border-radius:0 0 8px 8px;padding:10px 20px;font-size:14px;font-weight:700;text-decoration:none;transition:top .2s;position:fixed;top:-100%;left:16px}.skip-link:focus{top:0}button,input,select{font:inherit}button:focus-visible,input:focus-visible,select:focus-visible{outline-offset:2px;outline:3px solid #3478f647}.app-shell{grid-template-rows:64px minmax(0,1fr) 36px;height:100vh;display:grid;overflow:hidden}.top-bar{background:var(--surface);border-bottom:1px solid var(--border);z-index:5;grid-template-columns:auto auto minmax(0,1fr) auto;align-items:center;gap:16px;padding:0 22px;display:grid;position:relative;overflow:hidden}.top-bar__actions{min-width:0}.brand{letter-spacing:-.02em;align-items:center;gap:11px;font-size:17px;font-weight:750;display:flex}.brand__mark{background:var(--text);color:#fff;border-radius:10px;place-items:center;width:34px;height:34px;font-size:16px;display:grid}.project-title{justify-items:center;line-height:1.2;display:grid}.title-button{color:var(--text);cursor:text;background:0 0;border:1px solid #0000;border-radius:5px;padding:2px 8px;font-size:14px;font-weight:700;transition:border-color .15s}.title-button:hover{border-color:var(--border);background:var(--surface-subtle)}.title-input{width:220px;height:28px;color:var(--text);background:var(--surface);border:1px solid var(--selection);text-align:center;border-radius:5px;padding:0 8px;font-size:14px;font-weight:700}.project-title small{color:var(--muted);margin-top:4px;font-size:11px}.top-bar__actions{justify-content:flex-end;gap:10px;display:flex}.button{border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:38px;padding:0 15px;font-size:13px;font-weight:700;display:inline-flex}.button:disabled{cursor:not-allowed;opacity:.68}.icon-button{width:38px;height:38px;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:8px;place-items:center;display:grid}.icon-button:disabled{color:#a6adba;cursor:not-allowed}.button--secondary{background:var(--surface);color:var(--text);border-color:var(--border)}.button--primary{color:#fff;background:var(--accent)}.editor-layout{grid-template-columns:76px minmax(0,1fr) 320px;min-height:0;display:grid}.tool-rail{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;align-items:stretch;gap:8px;min-height:0;padding:14px 10px;display:flex;overflow-y:auto}.tool-button{min-height:58px;color:var(--muted);background:0 0;border:1px solid #0000;border-radius:9px;align-content:center;place-items:center;gap:4px;padding:7px 4px;font-size:10px;font-weight:650;display:grid}.tool-button:disabled{opacity:.55}.tool-button__chip{background:var(--muted);border-radius:10px;place-items:center;width:36px;height:36px;transition:transform .12s;display:grid;box-shadow:0 2px 6px #1720332e}.tool-button:not(:disabled):hover .tool-button__chip{transform:translateY(-1px)scale(1.05)}.tool-button--active{color:var(--selection);background:#edf4ff;border-color:#d4e4ff;opacity:1!important}.tool-button--newdoc{margin-top:auto}.tool-button--danger{color:var(--danger,#d92d20)}.tool-button--danger:not(:disabled):hover{background:#fdecea;border-color:#f4b9b2}.random-image-pool{flex-wrap:wrap;gap:8px;margin:8px 0;display:flex}.random-image-thumb{border:1px solid var(--border);background:var(--surface-subtle);border-radius:8px;width:52px;height:52px;position:relative;overflow:hidden}.random-image-thumb img{object-fit:contain;width:100%;height:100%}.random-image-thumb__missing{width:100%;height:100%;color:var(--muted);place-items:center;font-weight:700;display:grid}.random-image-thumb button{color:#fff;cursor:pointer;background:#0f1219b3;border:0;border-radius:50%;place-items:center;width:18px;height:18px;padding:0;font-size:13px;line-height:1;display:grid;position:absolute;top:1px;right:1px}.file-upload-button{cursor:pointer}.font-picker{position:relative}.font-picker__trigger{width:100%;min-height:34px;color:var(--text);background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:7px;justify-content:space-between;align-items:center;gap:8px;padding:6px 10px;display:flex}.font-picker__current{text-overflow:ellipsis;white-space:nowrap;font-size:14px;overflow:hidden}.font-picker__menu{z-index:400;border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow);border-radius:8px;flex-direction:column;display:flex;overflow:hidden}.font-picker__search{color:var(--muted);border-bottom:1px solid var(--border);align-items:center;gap:6px;padding:6px 9px;display:flex}.font-picker__search input{min-width:0;color:var(--text);background:0 0;border:0;outline:none;flex:1;font-size:12px}.font-picker__list{flex:1;min-height:0;max-height:260px;overflow-y:auto}.font-picker__group{color:var(--muted);letter-spacing:.04em;padding:6px 10px 2px;font-size:10px;font-weight:700}.font-picker__divider{background:var(--border);height:1px;margin:4px 0}.font-picker__item{align-items:center;gap:4px;display:flex}.font-picker__item.is-selected{background:#edf4ff}.font-picker__name{text-align:left;min-width:0;color:var(--text);white-space:nowrap;text-overflow:ellipsis;cursor:pointer;background:0 0;border:0;border-radius:0;flex:1;padding:7px 10px;font-size:16px;line-height:1.2;overflow:hidden}.font-picker__item:hover{background:var(--surface-subtle)}.font-picker__pin{color:#cbd5e1;cursor:pointer;background:0 0;border:0;border-radius:6px;place-items:center;width:28px;height:28px;margin-right:4px;display:grid}.font-picker__pin:hover{color:var(--muted);background:var(--surface)}.font-picker__pin.is-pinned{color:var(--accent)}.font-picker__empty{color:var(--muted);text-align:center;padding:14px 10px;font-size:12px}.font-picker__load{width:100%;color:var(--text);background:var(--surface-subtle);border:0;border-top:1px solid var(--border);cursor:pointer;padding:8px 10px;font-size:12px;font-weight:650}.font-picker__load:disabled{opacity:.6;cursor:default}.font-picker__hint{color:var(--muted);padding:8px 10px;font-size:11px;line-height:1.4;display:block}.workspace{min-width:0;padding:18px 26px 28px;overflow:auto}.design-bar{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.design-bar__divider{background:var(--border);align-self:stretch;width:1px;min-height:24px}.design-seg{background:var(--surface-subtle);border:1px solid var(--border);border-radius:9px;align-items:center;gap:4px;padding:3px;display:inline-flex}.design-seg__label{color:var(--muted);padding:0 4px 0 6px;font-size:12px;font-weight:700}.design-seg button{min-height:30px;color:var(--muted);cursor:pointer;background:0 0;border:0;border-radius:7px;padding:0 12px;font-size:13px;font-weight:700}.design-seg button.is-active{background:var(--surface);color:var(--text);box-shadow:0 1px 3px #0f172a1f}.design-chip{min-height:38px;color:var(--muted);background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:9px;align-items:center;gap:6px;padding:0 13px;font-size:13px;font-weight:700;display:inline-flex}.design-chip:hover{border-color:#c7d2e3}.design-chip.is-on{color:#0d9488;background:#f0fdfa;border-color:#5eead4}.design-unit{border:1px solid var(--border);background:var(--surface);min-height:38px;color:var(--text);border-radius:9px;padding:0 8px;font-size:13px;font-weight:700}.design-bar__template{color:#fff;cursor:pointer;background:linear-gradient(135deg,#14b8a6,#0d9488);border:0;border-radius:9px;align-items:center;gap:8px;min-height:38px;padding:0 16px;font-size:13px;font-weight:750;display:inline-flex;box-shadow:0 2px 8px #0d948859}.design-bar__template:hover{filter:brightness(1.05)}.design-bar__btn{min-height:38px;color:var(--text);background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:9px;align-items:center;gap:7px;padding:0 14px;font-size:13px;font-weight:700;display:inline-flex}.design-bar__btn:hover,.design-bar__btn.is-active{background:var(--surface-subtle);border-color:#c7d2e3}.design-popover{z-index:400;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:12px;overflow-y:auto}.design-popover .inspector__section{padding:14px 16px}.design-popover .inspector__section:not(:last-child){border-bottom:1px solid var(--border)}.inspector__hint{color:var(--muted);margin:0 0 10px;font-size:12px;line-height:1.5}.capacity-note{color:var(--muted);background:var(--surface-subtle);border:1px solid var(--border);border-radius:8px;margin:2px 0 12px;padding:8px 10px;font-size:12px;line-height:1.6}.capacity-note strong{color:var(--text)}.capacity-note__warn,.capacity-note__warn strong{color:#b45309}.pm-overlay{z-index:600;background:#0f172a73;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.pm-modal{background:var(--surface);border:1px solid var(--border);width:640px;max-width:100%;max-height:88vh;box-shadow:var(--shadow);border-radius:14px;flex-direction:column;display:flex;overflow:hidden}.pm-modal__header,.pm-modal__footer{justify-content:space-between;align-items:center;gap:10px;padding:12px 16px;display:flex}.pm-modal__header{border-bottom:1px solid var(--border)}.pm-modal__footer{border-top:1px solid var(--border)}.pm-modal__title{align-items:center;gap:8px;font-size:15px;font-weight:750;display:inline-flex}.pm-modal__close{width:30px;height:30px;color:var(--muted);cursor:pointer;background:0 0;border:0;border-radius:7px;place-items:center;display:grid}.pm-modal__close:hover{background:var(--surface-subtle)}.pm-modal__toolbar{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:10px;padding:10px 16px;display:flex}.pm-page{color:var(--muted);align-items:center;gap:6px;font-size:13px;display:inline-flex}.pm-page select{width:auto;min-height:32px}.pm-search{border:1px solid var(--border);min-width:120px;min-height:32px;color:var(--muted);border-radius:8px;flex:1;align-items:center;gap:6px;padding:0 10px;display:inline-flex}.pm-search input{background:0 0;border:0;flex:1;min-height:30px;padding:0}.pm-binding{color:#0d9488;background:#f0fdfa;border-radius:7px;padding:4px 10px;font-size:12px;font-weight:700}.pm-binding--idle{color:var(--muted);background:var(--surface-subtle)}.pm-modal__body{flex:1;padding:8px 16px 12px;overflow-y:auto}.pm-rule__title{color:var(--muted);margin:12px 0 6px;font-size:13px;font-weight:750}.pm-table{border-collapse:collapse;width:100%;font-size:13px}.pm-table th{text-align:center;color:var(--muted);border-bottom:1px solid var(--border);padding:6px 8px;font-weight:700}.pm-table th:first-child,.pm-table th.pm-col-use{text-align:left}.pm-table td{text-align:center;border-bottom:1px solid var(--border);padding:7px 8px}.pm-col-n{width:44px;text-align:left!important}.pm-col-op{width:34px;color:var(--muted)}.pm-col-use{color:var(--muted);font-size:12px;text-align:left!important}.pm-answer{font-weight:750}.pm-row--clickable{cursor:pointer}.pm-row--clickable:hover{background:var(--surface-subtle)}.pm-row--unused{background:#fffbeb}.pm-row--unused:hover{background:#fef3c7}.pm-unused-tag{color:#b45309;font-weight:700}.pm-row--bound{box-shadow:inset 3px 0 0 var(--selection);background:#eff6ff}.pm-hint{color:var(--muted);text-align:center;flex:1;font-size:12px}.pm-btn{border:1px solid var(--border);background:var(--surface);min-height:36px;color:var(--text);cursor:pointer;border-radius:9px;align-items:center;gap:6px;padding:0 14px;font-size:13px;font-weight:700;display:inline-flex}.pm-btn--danger{color:#b91c1c;background:#fef2f2;border-color:#fecaca}.pm-btn--primary{color:#fff;background:var(--accent);border-color:var(--accent)}.pm-btn:disabled{cursor:not-allowed;opacity:.58}.pm-btn--danger:disabled{color:var(--muted);border-color:var(--border);background:color-mix(in srgb, var(--surface) 86%, #f8fafc 14%)}[data-theme=dark] .pm-row--unused{background:#785a0a47}[data-theme=dark] .pm-row--bound{background:#3478f633}.insert-tool-group{border:1px solid var(--border);background:color-mix(in srgb, var(--surface) 92%, #fff 8%);border-radius:8px;gap:8px;margin:12px 0;padding:10px;display:grid}.insert-tool-group__header{gap:2px;display:grid}.insert-tool-group__header strong{color:var(--text);font-size:12px}.insert-tool-group__header span{color:var(--muted);font-size:11px;line-height:1.35}.insert-tool-group--tenframe{background:color-mix(in srgb, var(--surface) 88%, #fffbeb 12%);border-color:#f59e0b}.insert-vertical--tenframe{background:#b45309;border-color:#92400e}.tenframe-bind{color:var(--muted);flex-wrap:wrap;align-items:center;gap:6px;margin:8px 0 6px;font-size:12px;display:flex}.tenframe-bind label{border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:7px;align-items:center;gap:4px;padding:3px 9px;font-weight:700;display:inline-flex}.tenframe-bind label.is-active{color:#0d9488;background:#f0fdfa;border-color:#5eead4}.field-row{align-items:flex-end;gap:8px;display:flex}.field-row>.field{flex:1;min-width:0}.context-bar{background:var(--surface);border:1px solid var(--border);border-radius:10px;align-items:center;gap:6px;max-width:900px;height:48px;margin:0 auto 12px;padding:6px 10px;display:flex;overflow:auto hidden;box-shadow:0 1px 4px #1720330f}.context-bar__group,.context-btn,.context-field,.context-bar .font-picker,.context-bar__count{flex-shrink:0}.context-bar--empty{color:var(--muted);box-shadow:none;background:0 0;border-style:dashed;justify-content:center;font-size:12px}.context-bar__count{color:var(--muted);padding:0 4px;font-size:12px;font-weight:750}.context-bar__sep{background:var(--border);align-self:stretch;width:1px;margin:2px 4px}.context-bar__group{align-items:center;gap:4px;display:flex}.context-btn{min-height:30px;color:var(--text);background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:7px;align-items:center;gap:6px;padding:0 10px;font-size:12px;font-weight:650;display:inline-flex}.context-btn:hover{background:var(--surface-subtle)}.context-btn--icon{justify-content:center;width:32px;padding:0}.context-btn--danger{color:var(--danger,#d92d20);border-color:#f4b9b2}.context-btn--danger:hover{background:#fdecea}.context-bar__group--format{align-items:flex-end}.context-bar .field{margin-top:0}.context-bar .font-picker{width:188px}.context-bar .font-picker>span{display:none}.context-field{color:var(--muted);align-items:center;gap:5px;font-size:11px;font-weight:650;display:flex}.context-field input{width:56px;min-height:30px;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:7px;padding:0 6px}.context-color{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:7px;width:34px;height:30px;padding:2px}.op-segmented{gap:4px;display:flex}.op-seg-btn{min-height:36px;color:var(--text);background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:8px;flex:1;place-items:center;font-size:18px;font-weight:750;display:grid}.op-seg-btn:hover{background:var(--surface-subtle)}.op-seg-btn.is-active{color:#fff;background:var(--accent);border-color:var(--accent-hover)}.inspector__zone{background:var(--text);color:var(--surface);letter-spacing:.04em;padding:9px 18px;font-size:11px;font-weight:750}.workspace__bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px 16px;max-width:1180px;margin:0 auto 8px;display:flex}.workspace__view{flex-wrap:wrap;align-items:center;gap:7px;display:flex}.page-nav{align-items:center;gap:4px;display:flex}.page-nav__counter{color:var(--muted);white-space:nowrap;padding:0 8px;font-size:13px;font-weight:700}.segmented-control{background:#e7ebf2;border-radius:8px;padding:3px;display:flex}.segmented-control button{min-height:30px;color:var(--muted);background:0 0;border:0;border-radius:6px;padding:0 11px;font-size:11px;font-weight:700}.segmented-control button.is-active{color:var(--text);background:var(--surface);box-shadow:0 1px 4px #1720331f}.segmented-control button:disabled{opacity:.45}.page-button{width:32px;height:32px;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:7px;place-items:center;display:grid}.page-button--active{color:var(--selection);background:#edf4ff;border-color:#d4e4ff}.page-button:disabled{color:#a6adba}.page-stage{background-color:#e4e8ee;background-image:linear-gradient(45deg,#ffffff47 25%,#0000 25%),linear-gradient(-45deg,#ffffff47 25%,#0000 25%),linear-gradient(45deg,#0000 75%,#ffffff47 75%),linear-gradient(-45deg,#0000 75%,#ffffff47 75%);background-position:0 0,0 8px,8px -8px,-8px 0;background-size:16px 16px;border:1px solid #e1e5ec;border-radius:12px;place-items:start center;min-height:calc(100vh - 172px);padding:28px;display:grid}.canvas-page{box-shadow:var(--shadow);background:#fff 50%/100% 100% no-repeat;border:1px solid #dfe3ea;flex:none}.canvas-error{color:#b42318;text-align:center;background:#fff5f4;border:1px solid #f5c7c2;border-radius:10px;align-content:center;place-items:center;gap:8px;width:408px;min-height:180px;padding:28px;display:grid}.canvas-error span{color:#7a271a;font-size:12px;line-height:1.5}.inspector{background:var(--surface);border-left:1px solid var(--border);min-height:0;overflow:auto}.inspector__header{border-bottom:1px solid var(--border);z-index:3;background:var(--surface);justify-content:space-between;align-items:center;gap:10px;min-height:68px;padding:14px 18px;display:flex;position:sticky;top:0}.inspector__header p,.inspector__header span{margin:0}.inspector__header>div{flex:1;min-width:0}.inspector__header p{font-size:14px;font-weight:750}.inspector__header span{color:var(--muted);margin-top:4px;font-size:11px;display:block}.inspector__section{border-bottom:1px solid var(--border);padding:18px}.inspector__section h2{text-transform:uppercase;letter-spacing:.08em;margin:0 0 14px;font-size:12px}.inspector>.inspector__section>h2{z-index:2;background:var(--surface-subtle);border-bottom:1px solid var(--border);margin:-18px -18px 14px;padding:10px 18px;position:sticky;top:68px}.field{gap:7px;margin-top:10px;display:grid}.field>span{color:var(--muted);font-size:11px;font-weight:650}.field select{width:100%;height:38px;color:var(--text);background:var(--surface-subtle);border:1px solid var(--border);border-radius:7px;padding:0 10px;font-size:13px}.field input{width:100%;height:38px;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:7px;padding:0 10px;font-size:13px}.inspector__actions{grid-template-columns:1fr 1fr;gap:8px;margin-top:14px;display:grid}.inspector__actions button{min-height:34px;color:var(--text);background:var(--surface-subtle);border:1px solid var(--border);border-radius:7px;justify-content:center;align-items:center;gap:6px;font-size:11px;font-weight:700;display:inline-flex}.inspector__actions .danger-action{color:#b42318;background:#fff5f4;border-color:#f5c7c2}.align-toolbar{flex-wrap:wrap;gap:4px;display:flex}.align-btn{border:1px solid var(--border);background:var(--surface);width:38px;height:34px;color:var(--text);cursor:pointer;border-radius:6px;place-items:center;font-size:12px;transition:all .15s;display:grid}.align-btn:hover{background:var(--surface-subtle);border-color:var(--accent);color:var(--accent)}.loading-overlay{z-index:300;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f121973;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.loading-card{background:var(--surface);width:min(320px,86vw);box-shadow:var(--shadow);text-align:center;border-radius:18px;flex-direction:column;align-items:center;gap:12px;padding:26px 28px 24px;display:flex}.loader-mascot{width:104px;height:104px}.loader-mascot__bob{transform-origin:60px 60px;animation:1.3s ease-in-out infinite mascot-bob}.loader-mascot__pencil{transform-origin:90px 47px;animation:.9s ease-in-out infinite mascot-write}.loader-mascot__dots circle{animation:1.2s ease-in-out infinite mascot-dot}.loader-mascot__dots circle:nth-child(2){animation-delay:.2s}.loader-mascot__dots circle:nth-child(3){animation-delay:.4s}@keyframes mascot-bob{0%,to{transform:translateY(0)rotate(-2deg)}50%{transform:translateY(-7px)rotate(2deg)}}@keyframes mascot-write{0%,to{transform:rotate(0)}50%{transform:rotate(-9deg)}}@keyframes mascot-dot{0%,to{opacity:.3;transform:translateY(0)}50%{opacity:1;transform:translateY(-3px)}}.loading-message{color:var(--text);margin:0;font-size:15px;font-weight:750}.loading-bar{background:var(--surface-subtle);border:1px solid var(--border);border-radius:999px;width:100%;height:9px;overflow:hidden}.loading-bar__fill{background:var(--accent);border-radius:999px;height:100%;transition:width .25s}.loading-subtext{color:var(--muted);margin:0;font-size:12px;font-weight:650}@media (prefers-reduced-motion:reduce){.loader-mascot__bob,.loader-mascot__pencil,.loader-mascot__dots circle{animation:none}}.export-progress-overlay{z-index:250;background:#00000073;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.export-progress-modal{text-align:center;background:#fff;border-radius:14px;min-width:320px;padding:28px 36px;animation:.2s slideUp;box-shadow:0 20px 40px #0003}.export-progress-header{color:#172033;justify-content:center;align-items:center;gap:10px;margin-bottom:16px;font-size:16px;font-weight:700;display:flex}.export-progress-spinner{border:3px solid #e2e8f0;border-top-color:var(--accent);border-radius:50%;width:18px;height:18px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.export-progress-bar-bg{background:#e2e8f0;border-radius:5px;height:10px;overflow:hidden}.export-progress-bar-fill{background:linear-gradient(90deg, var(--accent), #4f8cff);border-radius:5px;height:100%;transition:width .3s}.export-progress-info{color:#64748b;margin-top:10px;font-size:13px}.insert-grid{grid-template-columns:repeat(4,1fr);gap:7px;display:grid}.insert-grid button{color:#245bb2;background:#f1f6ff;border:1px solid #d4e4ff;border-radius:7px;min-height:34px;font-size:11px;font-weight:750}.insert-vertical{color:#fff;cursor:pointer;background:#245bb2;border:1px solid #1d4a93;border-radius:7px;width:100%;min-height:34px;margin-top:7px;font-size:11px;font-weight:750}.insert-vertical:hover{background:#1d4a93}.rule-tabs{flex-wrap:wrap;gap:4px;display:flex}.rule-tab{color:#245bb2;cursor:pointer;background:#f8faff;border:1px solid #d4e4ff;border-radius:6px;padding:5px 10px;font-size:11px;font-weight:600;transition:all .15s}.rule-tab:hover{background:#e8f0ff}.rule-tab--active{color:#fff;background:#245bb2;border-color:#1d4a93}.rule-tab--add{color:#34d399;background:#ecfdf5;border-color:#a7f3d0;padding:3px 10px;font-size:14px;font-weight:800}.rule-tab--add:hover{background:#d1fae5}.wide-action--danger{color:#dc2626;background:#fef2f2;border-color:#fca5a5}.wide-action--danger:hover{background:#fee2e2}.field-hint{color:var(--muted);margin:6px 0 0;font-size:10px;line-height:1.4}.mode-switch{margin-left:12px}.bingo-layout{flex:1;grid-template-columns:260px 1fr 260px;gap:16px;min-height:0;padding:16px;display:grid;overflow:hidden}.bingo-panel{border:1px solid var(--border,#e2e8f0);background:#fff;border-radius:12px;padding:14px;overflow-y:auto}.bingo-panel h2{margin:0 0 10px;font-size:13px}.bingo-add{gap:6px;margin-bottom:8px;display:flex}.bingo-add input{flex:1;min-width:0}.bingo-add button{color:#fff;cursor:pointer;background:#245bb2;border:1px solid #1d4a93;border-radius:7px;padding:0 12px;font-weight:700}.bingo-item-list{flex-direction:column;gap:4px;margin:10px 0 4px;padding:0;list-style:none;display:flex}.bingo-item-list li{background:#f5f8ff;border-radius:6px;justify-content:space-between;align-items:center;gap:8px;padding:5px 8px;font-size:12px;display:flex}.bingo-item-list button{color:#b42318;cursor:pointer;background:0 0;border:none;display:inline-flex}.bingo-empty,.bingo-count{color:var(--muted);font-size:11px}.bingo-preview{flex-direction:column;gap:12px;min-height:0;display:flex;overflow-y:auto}.bingo-card-preview{flex-direction:column;align-items:center;gap:8px;display:flex}.bingo-card-preview__number{color:var(--muted);font-weight:750}.bingo-grid{aspect-ratio:1;background:#cbd5e1;border:2px solid #3c465a;border-radius:8px;gap:4px;width:min(100%,460px);padding:4px;display:grid}.bingo-cell{text-align:center;background:#fff;border-radius:4px;justify-content:center;align-items:center;padding:2px;font-size:12px;font-weight:650;display:flex;overflow:hidden}.bingo-cell--free{color:#245bb2;background:#ebf2ff;font-weight:800}.bingo-cell img{object-fit:contain;max-width:100%;max-height:100%}.bingo-status{text-align:center;font-size:12px}.bingo-status--error{color:#b42318}.bingo-status--done{color:#027a48}.empty-selection{color:var(--muted);margin:0;font-size:12px;line-height:1.5}.numeric-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin:10px 0;display:grid}.numeric-grid label{color:var(--muted);gap:4px;font-size:11px;font-weight:700;display:grid}.numeric-grid input{width:100%;min-width:0}.layout-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;margin:8px 0;display:grid}.layout-actions button,.wide-action{border:1px solid var(--border);min-height:32px;color:var(--ink);cursor:pointer;background:#fff;border-radius:7px;font-size:11px}.wide-action{width:100%;font-weight:750}.wide-action--primary{color:#fff;background:var(--accent);border-color:var(--accent-hover);justify-content:center;align-items:center;gap:8px;min-height:38px;font-size:13px;display:flex}.wide-action--primary:hover:not(:disabled){background:var(--accent-hover)}.wide-action:disabled{cursor:not-allowed;opacity:.45}.overflow-warning{color:#17643a;background:#edf9f2;border-radius:7px;margin-top:10px;padding:9px 10px;font-size:11px;font-weight:750}.overflow-warning.is-warning{color:#9a4d00;background:#fff4e5}.range-row{grid-template-columns:30px 1fr 24px 1fr 64px;align-items:center;gap:7px;margin-top:9px;font-size:12px;display:grid}.range-row select{height:34px;color:var(--text);background:var(--surface-subtle);border:1px solid var(--border);border-radius:7px;padding:0 4px;font-size:11px}.range-row output{background:var(--surface-subtle);border:1px solid var(--border);border-radius:7px;place-items:center;height:34px;font-weight:700;display:grid}.range-row input{width:100%;height:34px;color:var(--text);background:var(--surface-subtle);border:1px solid var(--border);text-align:center;border-radius:7px;padding:0 7px;font-size:12px;font-weight:700}.check-field,.visibility-options label{color:var(--text);align-items:center;gap:8px;font-size:12px;font-weight:650;display:flex}.check-field{margin-top:12px}.check-field input,.visibility-options input{width:16px;height:16px;accent-color:var(--selection)}.visibility-options{background:var(--surface-subtle);border:1px solid var(--border);border-radius:8px;gap:10px;margin-top:14px;padding:12px;display:grid}.range-row__dash{color:var(--muted);text-align:center}.summary-row{min-height:34px;color:var(--muted);justify-content:space-between;align-items:center;gap:18px;font-size:12px;display:flex}.summary-row strong{max-width:150px;color:var(--text);text-align:right;text-overflow:ellipsis;font-size:12px;overflow:hidden}.inspector__notice{border-left:3px solid var(--selection);background:#f0f5ff;margin:18px;padding:14px}.export-status{background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;gap:8px;margin:18px;padding:14px;display:grid}.export-status strong{font-size:12px}.export-status span{color:var(--muted);font-size:11px}.export-status progress{width:100%;accent-color:var(--selection)}.export-status--complete{background:#ecfdf3;border-color:#abefc6}.export-status--error{color:#b42318;background:#fff5f4;border-color:#f5c7c2}.validation-list{gap:6px;margin-bottom:12px;display:grid}.validation-item{border-radius:7px;align-items:flex-start;gap:7px;padding:8px 10px;font-size:11px;line-height:1.5;display:flex}.validation-item--error{color:#b42318;background:#fff5f4;border:1px solid #f5c7c2}.validation-item--warning{color:#9a4d00;background:#fff4e5;border:1px solid #fcd9a4}.validation-item--ok{color:#17643a;background:#ecfdf3;border:1px solid #abefc6;border-radius:7px;margin-bottom:10px;padding:8px 10px;font-size:11px;font-weight:700}.export-buttons{flex-direction:column;gap:0;display:flex}.inspector__reset-defaults{width:32px;height:32px;color:var(--muted);background:var(--surface-subtle);border:1px solid var(--border);cursor:pointer;border-radius:8px;flex:none;place-items:center;display:grid}.inspector__reset-defaults:hover{color:var(--ink);background:#fff}.server-export-target{width:100%;height:34px;color:var(--text);background:var(--surface-subtle);border:1px solid var(--border);border-radius:7px;margin:4px 0 10px;padding:0 8px;font-size:12px;font-weight:650}.server-export-list{gap:8px;margin:12px 0 0;padding:0;list-style:none;display:grid}.server-export-empty{color:var(--muted);background:var(--surface-subtle);border:1px dashed var(--border);border-radius:7px;padding:10px;font-size:11px}.server-export-job{border:1px solid var(--border);background:#fff;border-radius:7px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;padding:10px;display:grid}.server-export-job__meta{gap:3px;min-width:0;display:grid}.server-export-job__meta strong,.server-export-job__meta span,.server-export-job__meta small{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.server-export-job__meta strong{color:var(--text);font-size:12px}.server-export-job__meta span{color:var(--muted);font-size:10px}.server-export-job__meta small{color:#b42318;font-size:10px}.server-export-status{color:#175cd3;text-align:center;background:#eff6ff;border:1px solid #bfdbfe;border-radius:999px;min-width:62px;padding:4px 7px;font-size:10px;font-weight:800}.server-export-status--complete{color:#17643a;background:#ecfdf3;border-color:#abefc6}.server-export-status--failed{color:#b42318;background:#fff5f4;border-color:#f5c7c2}.server-export-status--cancelled{color:#475467;background:#f2f4f7;border-color:#d0d5dd}.server-export-actions{grid-column:1/-1;grid-template-columns:repeat(3,32px);justify-content:end;gap:6px;display:grid}.server-export-actions button{width:32px;height:30px;color:var(--text);background:var(--surface-subtle);border:1px solid var(--border);cursor:pointer;border-radius:7px;place-items:center;display:grid}.server-export-actions button:disabled{cursor:not-allowed;opacity:.42}.inspector__notice strong{font-size:12px}.inspector__notice p{color:var(--muted);margin:6px 0 0;font-size:11px;line-height:1.5}.status-bar{color:var(--muted);background:var(--surface);border-top:1px solid var(--border);align-items:center;gap:20px;padding:0 16px 0 90px;font-size:11px;display:flex}.status-bar__spacer{flex:1}.status-bar__undo{color:var(--selection);font-weight:700}.status-bar__shortcut{color:#a0aab8;letter-spacing:.02em;-webkit-user-select:none;user-select:none;font-size:10px}.status-bar__fit{border-radius:5px;width:26px;height:26px;font-size:14px;line-height:1}.zoom-control{align-items:center;gap:7px;display:flex}.zoom-control input{width:90px;accent-color:var(--selection)}.zoom-control output{min-width:34px;color:var(--text);font-weight:700}.visually-hidden{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@media (height<=760px){.page-stage{min-height:560px}}.thumb-rail{border-top:1px solid var(--border);background:var(--surface-subtle);align-items:flex-end;gap:10px;padding:14px 28px;display:flex;overflow-x:auto}.thumb-item{cursor:pointer;background:0 0;border:2px solid #0000;border-radius:6px;flex-direction:column;flex-shrink:0;align-items:center;gap:5px;padding:4px;transition:border-color .12s;display:flex}.thumb-item:hover{border-color:var(--border)}.thumb-item--active{border-color:var(--selection);background:#edf4ff}.thumb-canvas{border:1px solid var(--border);background:#fff;border-radius:3px;width:72px;height:94px;display:block;box-shadow:0 2px 6px #17203314}.thumb-label{color:var(--muted);font-size:10px;font-weight:700}.thumb-item--active .thumb-label{color:var(--selection)}.thumb-more{color:var(--muted);white-space:nowrap;align-items:center;padding:0 8px;font-size:11px;display:flex}.template-overlay{z-index:200;background:#00000080;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.template-modal{background:#fff;border-radius:16px;width:640px;max-width:90vw;max-height:80vh;padding:32px;animation:.25s slideUp;overflow-y:auto;box-shadow:0 24px 48px #00000040}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.template-modal__header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.template-modal__header h2{color:#172033;font-size:22px;font-weight:700}.template-modal__close{cursor:pointer;color:#64748b;background:#f1f5f9;border:none;border-radius:8px;width:32px;height:32px;font-size:16px;transition:background .15s}.template-modal__close:hover{background:#e2e8f0}.template-modal__subtitle{color:#64748b;margin-bottom:20px;font-size:14px}.start-blank{background:var(--surface-subtle);border:1px solid var(--border);border-radius:12px;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:18px;padding:14px 16px;display:flex}.start-blank__size{color:var(--muted);align-items:center;gap:8px;font-size:13px;font-weight:700;display:flex}.size-btn{min-height:34px;color:var(--text);background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:8px;padding:0 14px;font-size:13px;font-weight:650}.size-btn.is-active{color:#fff;background:var(--accent);border-color:var(--accent-hover)}.start-blank .wide-action{flex:1;width:auto;min-width:180px;min-height:38px}.template-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.template-card{cursor:pointer;background:#fafbfc;border:2px solid #e2e8f0;border-radius:12px;flex-direction:column;align-items:center;gap:6px;padding:20px 12px;transition:all .2s;display:flex}.template-card:hover{background:#f0f4ff;border-color:#245bb2;transform:translateY(-2px);box-shadow:0 4px 12px #245bb226}.template-card__icon{font-size:28px}.template-card__name{color:#172033;font-size:14px;font-weight:700}.template-card__desc{color:#64748b;text-align:center;font-size:11px;line-height:1.3}.error-boundary{background:var(--background);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.error-boundary__card{background:var(--surface);border:1px solid var(--border);max-width:520px;box-shadow:var(--shadow);border-radius:12px;padding:32px}.error-boundary__card h1{color:var(--text);margin:0 0 12px;font-size:20px}.error-boundary__card p{color:var(--muted);margin:0 0 16px;line-height:1.5}.error-boundary__detail{background:var(--surface-subtle);border:1px solid var(--border);color:var(--text);white-space:pre-wrap;word-break:break-word;overflow-wrap:anywhere;border-radius:8px;margin:0 0 20px;padding:12px;font-size:12px}.error-boundary__actions{flex-wrap:wrap;gap:12px;display:flex}[data-theme=dark] .danger-action,[data-theme=dark] .inspector__actions .danger-action{color:#f87171;background:#ef44441f;border-color:#ef444440}[data-theme=dark] .export-progress-modal,[data-theme=dark] .template-modal{background:var(--surface);color:var(--text)}[data-theme=dark] .export-progress-header{color:var(--text)}[data-theme=dark] .export-progress-bar-bg{background:var(--border)}[data-theme=dark] .export-progress-info{color:var(--muted)}[data-theme=dark] .template-card{background:var(--surface-subtle);border-color:var(--border)}[data-theme=dark] .template-card:hover{border-color:var(--accent)}[data-theme=dark] .template-card__desc{color:var(--muted)}[data-theme=dark] .mode-switch button.is-active{background:var(--accent)}[data-theme=dark] input,[data-theme=dark] select{background:var(--surface-subtle);color:var(--text);border-color:var(--border)}[data-theme=dark] .page-stage{background:var(--surface-subtle)}[data-theme=dark] .field input,[data-theme=dark] .field select{background:var(--surface);border-color:var(--border);color:var(--text)}.inspector-toggle{z-index:50;background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:50%;place-items:center;width:48px;height:48px;display:none;position:fixed;bottom:56px;right:16px;box-shadow:0 4px 16px #00000040}.inspector-backdrop{display:none}.inspector__close-mobile{background:var(--surface-subtle);cursor:pointer;width:32px;height:32px;color:var(--muted);border:none;border-radius:8px;place-items:center;display:none}@media (width<=1024px){.editor-layout{grid-template-columns:56px minmax(0,1fr) 280px}.tool-rail{padding:10px 6px}.tool-button{gap:3px;min-height:48px;font-size:9px}.top-bar{gap:12px;padding:0 12px}.top-bar__actions{gap:6px}.button{min-height:34px;padding:0 10px;font-size:12px}.status-bar__shortcut{display:none}}@media (width<=768px){.app-shell{grid-template-rows:auto minmax(0,1fr) 32px;height:auto;min-height:100vh;overflow:visible}.top-bar{flex-wrap:wrap;grid-template-columns:1fr 1fr;gap:6px;padding:8px 10px}.brand{gap:6px;font-size:14px}.brand__mark{border-radius:7px;width:28px;height:28px;font-size:13px}.project-title{order:3;grid-column:1/-1}.project-title small{display:none}.mode-switch{justify-self:end}.top-bar__actions{flex-wrap:wrap;order:4;grid-column:1/-1;justify-content:center;gap:4px}.top-bar__actions .button span{display:none}.editor-layout{grid-template-columns:1fr}.tool-rail{border-right:0;border-bottom:1px solid var(--border);flex-direction:row;align-items:stretch;gap:6px;padding:8px 10px;overflow-x:auto}.tool-button{flex:none;min-width:60px;min-height:52px}.tool-button--newdoc{margin-top:0;margin-left:auto}.context-bar{gap:4px;max-width:none;margin:0 0 10px}.context-bar .font-picker{width:150px}.start-blank{flex-direction:column;align-items:stretch}.start-blank__size{flex-wrap:wrap}.inspector{z-index:100;width:320px;max-width:85vw;transition:transform .3s cubic-bezier(.4,0,.2,1);position:fixed;top:0;bottom:0;right:0;transform:translate(100%);box-shadow:-4px 0 24px #00000026}.inspector--open{transform:translate(0)}.inspector-toggle{display:grid}.inspector-backdrop{z-index:90;background:#0006;animation:.2s fadeIn;display:block;position:fixed;inset:0}.inspector__close-mobile{display:grid}.status-bar{gap:8px;padding:0 8px;font-size:10px}.status-bar__spacer,.zoom-control{display:none}.bingo-layout{flex-direction:column}.bingo-panel{min-width:unset;width:100%}.bingo-preview{min-width:unset}.template-grid{grid-template-columns:repeat(2,1fr)}.template-modal{width:95vw;max-height:90vh;padding:20px}.page-stage{min-height:400px}.workspace__bar{flex-direction:column;align-items:stretch;gap:8px}}@media (width<=480px){.top-bar__actions{gap:3px}.button{min-height:30px;padding:0 8px;font-size:11px}.icon-button{width:30px;height:30px}.template-grid{grid-template-columns:1fr}.bingo-grid{gap:2px}.bingo-cell{font-size:10px}.inspector{width:100vw;max-width:100vw}}.auth-control{align-items:center;gap:8px;display:flex}.auth-control__user{text-overflow:ellipsis;white-space:nowrap;max-width:160px;color:var(--muted);font-size:13px;overflow:hidden}.auth-overlay{z-index:1000;background:#0f172a73;justify-content:center;align-items:center;padding:20px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.auth-modal{background:var(--surface);border:1px solid var(--border);width:100%;max-width:380px;box-shadow:var(--shadow);border-radius:14px;overflow:hidden}.auth-modal__header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.auth-tabs{gap:4px;display:flex}.auth-tabs button{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:6px 12px;font-size:14px;font-weight:600}.auth-tabs button.is-active{background:var(--surface-subtle);color:var(--text)}.auth-modal__close{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:4px 8px;font-size:16px}.auth-modal__close:hover{background:var(--surface-subtle)}.auth-form{flex-direction:column;gap:12px;padding:16px;display:flex}.auth-error{color:#b42318;background:#d92d201a;border-radius:8px;margin:0;padding:8px 10px;font-size:13px}[data-theme=dark] .auth-error{color:#fca5a5;background:#f8717126}.cloud-list{flex-direction:column;gap:6px;margin:12px 0 0;padding:0;list-style:none;display:flex}.cloud-empty{color:var(--muted);font-size:12px}.cloud-item{background:var(--surface-subtle);border:1px solid var(--border);border-radius:8px;justify-content:space-between;align-items:center;gap:8px;padding:6px 8px;display:flex}.cloud-item__title{text-overflow:ellipsis;white-space:nowrap;font-size:13px;overflow:hidden}.cloud-item__actions{flex:none;gap:4px;display:flex}.cloud-item__actions button{width:28px;height:28px;color:var(--muted);background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:6px;place-items:center;display:grid}.cloud-item__actions button:hover:not(:disabled){color:var(--text)}.cloud-item__actions button:disabled{opacity:.5;cursor:not-allowed}.account-subhead{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin:4px 0 0;font-size:12px;font-weight:700}.account-badge{color:var(--selection);background:#3478f61f;border-radius:999px;margin-left:6px;padding:1px 6px;font-size:10px;font-weight:700;display:inline-block}.auth-control__account{max-width:220px}.auth-control__account .auth-control__user{max-width:150px}.cloud-item__title{flex-direction:column;min-width:0;display:flex}.cloud-item__when{color:var(--muted);font-size:10px}.onboarding-overlay{z-index:8000;background:#0000008c;animation:.3s fadeIn;position:fixed;inset:0}.onboarding-highlight{border:2px solid var(--accent);z-index:8001;pointer-events:none;border-radius:10px;transition:all .35s cubic-bezier(.4,0,.2,1);position:absolute;box-shadow:0 0 0 9999px #0000008c}.onboarding-tooltip{z-index:8002;background:var(--surface);color:var(--text);border-radius:14px;max-width:320px;padding:20px 24px;animation:.3s tooltipPop;position:fixed;box-shadow:0 12px 40px #0003}.onboarding-tooltip h3{margin:0 0 6px;font-size:16px;font-weight:700}.onboarding-tooltip p{color:var(--muted);margin:0 0 16px;font-size:13px;line-height:1.5}.onboarding-actions{justify-content:space-between;align-items:center;display:flex}.onboarding-dots{gap:6px;display:flex}.onboarding-dot{background:var(--border);border-radius:50%;width:8px;height:8px;transition:background .2s}.onboarding-dot.active{background:var(--accent);transform:scale(1.2)}.onboarding-buttons{gap:8px;display:flex}.onboarding-skip{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:6px 12px;font-size:12px}.onboarding-skip:hover{background:var(--surface-subtle)}.onboarding-next{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:6px 16px;font-size:12px;font-weight:600;transition:background .15s}.onboarding-next:hover{background:var(--accent-hover)}@keyframes tooltipPop{0%{opacity:0;transform:translateY(-50%)scale(.92)}to{opacity:1;transform:translateY(-50%)scale(1)}}.skeleton-list{flex-direction:column;gap:6px;margin-top:12px;display:flex}.skeleton{background:linear-gradient(90deg, var(--surface-subtle) 25%, var(--border) 37%, var(--surface-subtle) 63%);background-size:400% 100%;border-radius:8px;animation:1.4s infinite skeleton-shimmer}.skeleton-row{height:34px}@keyframes skeleton-shimmer{0%{background-position:100%}to{background-position:0}}
