:root{color:#172033;background:#e8edf2;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;min-width:320px;min-height:100vh;min-height:100dvh}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{display:grid;grid-template-columns:clamp(220px,20vw,300px) minmax(0,1fr) clamp(240px,22vw,320px);gap:12px;height:100vh;min-height:0;overflow:hidden;padding:12px}.mobile-shell{display:none}.panel,.preview-shell{min-width:0;background:#ffffffd1;border:1px solid rgba(124,139,159,.28);border-radius:8px;box-shadow:0 18px 46px #202d4614}.controls,.component-inspector-panel{padding:14px;overflow:auto;overflow-x:hidden}.brand-block{position:relative;display:flex;align-items:center;gap:12px;padding-bottom:16px;border-bottom:1px solid #dbe2ea}.brand-copy{min-width:0;flex:1}.mark{display:grid;place-items:center;width:42px;height:42px;border-radius:8px;background:#111827;color:#f8fafc;font-size:22px;font-weight:800}.eyebrow{margin:0 0 4px;color:#64748b;font-size:11px;font-weight:800;letter-spacing:0;text-transform:uppercase}h1,h2{margin:0;color:#121826;font-size:18px;line-height:1.25}h1{font-size:20px}.control-group{min-width:0;margin-top:18px}.control-group>label,.inline-label label{display:block;margin-bottom:8px;color:#334155;font-size:13px;font-weight:800}.inline-label{display:flex;align-items:center;justify-content:space-between;gap:10px}.compact-label{margin-bottom:8px}.compact-label label{margin-bottom:0}.small-action{border:1px solid #cbd5e1;border-radius:7px;background:#f8fafc;color:#334155;font-size:12px;font-weight:800;padding:5px 8px;cursor:pointer}.small-action:hover{border-color:#f97316;color:#9a3412}.preset-actions{display:grid;gap:8px;margin-bottom:10px}.preset-actions>span{color:#334155;font-size:13px;font-weight:800}.preset-chip-list{display:flex;flex-wrap:wrap;gap:7px}.preset-chip-list button{min-height:30px;border:1px solid #cbd5e1;border-radius:7px;background:#f8fafc;color:#334155;font-size:12px;font-weight:800;padding:0 10px}.preset-chip-list button:hover{border-color:#f97316;color:#9a3412}.component-action-list{display:grid;gap:7px;min-width:0}.component-action-list button{display:flex;align-items:center;justify-content:space-between;min-width:0;min-height:34px;width:100%;border:1px solid #cbd5e1;border-radius:7px;background:#fff;color:#0f172a;font-size:12px;font-weight:900;padding:0 10px}.component-action-list button span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.component-action-list button:hover{border-color:#38bdf8;background:#f0f9ff;color:#075985}.component-action-list button:disabled{cursor:not-allowed;opacity:.45}.fold-toggle,.text-toggle{border:1px solid #cbd5e1;border-radius:7px;background:#f8fafc;color:#27364a;font-size:13px;font-weight:800}.fold-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;min-height:30px;border-color:transparent;background:transparent;padding:0;color:#475569;font-weight:700}.fold-toggle b{color:#94a3b8;font-size:12px;font-weight:700}.text-toggle{min-height:30px;padding:0 9px}.segmented,.option-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}.option-grid{grid-template-columns:repeat(3,1fr)}.segmented button,.option-grid button,.export-actions button,.icon-text{min-height:38px;border:1px solid #cbd5e1;border-radius:7px;background:#f8fafc;color:#27364a;font-size:13px;font-weight:750}.segmented button.active,.option-grid button.active{border-color:#111827;background:#111827;color:#fff}.deck-summary-control{gap:10px}.deck-summary-header{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;min-height:38px;border:1px solid #cbd5e1;border-radius:7px;background:#fff;padding:4px 5px 4px 11px}.deck-summary-header.open{border-bottom-color:#e2e8f0;border-radius:7px 7px 0 0}.deck-summary-copy{min-width:0;overflow:hidden;color:#27364a;font-size:13px;font-weight:850;text-overflow:ellipsis;white-space:nowrap}.deck-summary-size,.deck-summary-badge{color:#64748b;font-weight:600}.deck-summary-header button{min-height:28px;border:0;border-radius:6px;background:#f1f5f9;color:#475569;padding:0 9px;font-size:12px;font-weight:850}.deck-summary-header button:hover{background:#e2e8f0;color:#111827}.deck-summary-editor{display:grid;gap:11px;margin-top:-10px;border:1px solid #cbd5e1;border-top:0;border-radius:0 0 7px 7px;background:#fff;padding:12px}.deck-editor-row{display:grid;grid-template-columns:40px minmax(0,1fr);align-items:start;gap:10px}.deck-editor-row>span{padding-top:8px;color:#64748b;font-size:12px;font-weight:850}.compact-deck-segmented button{min-height:30px;font-size:12px}.deck-size-fields{display:grid;gap:10px}.deck-custom-size-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:7px;border-top:1px solid #e2e8f0;padding-top:10px}.grip-sheet-size-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.deck-custom-size-grid .number-input span{margin-bottom:4px;font-size:11px}.deck-custom-size-grid .number-input input{min-height:32px;border-radius:6px;-webkit-appearance:textfield;-moz-appearance:textfield;appearance:textfield;padding:0 8px;font-size:12px}.deck-custom-size-grid .number-input input::-webkit-inner-spin-button,.deck-custom-size-grid .number-input input::-webkit-outer-spin-button{margin:0;-webkit-appearance:none;-moz-appearance:none;appearance:none}.deck-custom-size-grid .number-input small{margin-top:4px;font-size:10px;line-height:1.2}select,.number-input input{width:100%;min-height:38px;border:1px solid #cbd5e1;border-radius:7px;background:#fff;color:#172033;padding:0 10px}.control-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:16px}.unit-toggle{width:112px}.advanced-unit-toggle{margin-top:10px}.unit-toggle button{min-height:30px;text-transform:uppercase}.preset-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(68px,1fr));gap:6px}.preset-grid button{min-width:0;min-height:32px;border:1px solid #cbd5e1;border-radius:7px;background:#f8fafc;color:#27364a;padding:0 6px;font-size:12px;font-weight:800;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preset-grid button:hover{border-color:#111827}.preset-grid button.active{border-color:#111827;background:#111827;color:#fff}.template-library{padding-bottom:2px}.template-library-toggle{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;width:100%;min-height:28px;border:0;background:transparent;color:#334155;padding:0;text-align:left}.template-library-toggle span{font-size:13px;font-weight:800}.template-library-toggle svg{color:#94a3b8}.template-chip-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.template-chip-list button{flex:0 1 auto;min-width:0;min-height:28px;border:1px solid #dbe2ea;border-radius:999px;background:#f8fafc;color:#475569;padding:0 9px;font-size:12px;font-weight:800;text-align:center;width:max-content;max-width:100%}.template-chip-list button span{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.template-chip-list button:hover{border-color:#94a3b8;background:#fff;color:#111827}.appearance-control-body{display:grid;gap:8px;margin-top:8px}.appearance-control-body .color-row{margin-top:0}.mobile-size-toggle{display:none}.number-input span,.range-row span{display:block;margin-bottom:6px;color:#64748b;font-size:12px;font-weight:750}.number-input small{display:block;margin-top:5px;color:#94a3b8;font-size:11px;font-weight:700}.range-row{display:grid;grid-template-columns:78px 1fr 34px;align-items:center;gap:10px;margin-top:10px}.range-row span{margin:0}.range-row input{width:100%;accent-color:#111827}.range-row b{color:#334155;font-size:12px;text-align:right}.toggle-row{display:flex;align-items:center;gap:8px;margin-top:10px;color:#475569;font-size:12px;font-weight:800}.toggle-row input{width:16px;height:16px;accent-color:#111827}.color-row{display:grid;grid-template-columns:42px 1fr 34px;align-items:center;gap:8px;margin-top:9px}.color-row>span{color:#64748b;font-size:12px;font-weight:800}.swatches{display:flex;flex-wrap:nowrap;gap:4px;min-width:0}.swatches button{flex:0 0 auto;width:17px;height:17px;border:2px solid #ffffff;border-radius:999px;box-shadow:0 0 0 1px #cbd5e1}.swatches button.active{box-shadow:0 0 0 2px #111827}.color-row input[type=color]{width:34px;height:30px;border:1px solid #cbd5e1;border-radius:7px;background:#fff;padding:2px}.icon-text{display:inline-flex;align-items:center;gap:6px;min-height:30px;padding:0 9px}.main-column{display:grid;grid-template-rows:1fr auto;gap:12px;min-height:0;min-width:0}.preview-shell{position:relative;display:grid;grid-template-rows:auto 1fr auto;min-height:0;overflow:hidden;padding:14px}.preview-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.preview-header>div:first-child{min-width:0}.preview-header-actions{display:flex;align-items:center;flex:0 0 auto;gap:8px}.drawing-toolbar-dock{position:absolute;top:16px;left:50%;z-index:5;display:flex;align-items:center;gap:8px;transform:translate(-50%)}.drawing-toolbar-dock.collapsed{gap:0;top:12px}.drawing-tool-palette,.drawing-toolbar,.drawing-toolbar-toggle{display:flex;align-items:center;gap:4px;min-height:34px;border:1px solid rgba(15,23,42,.1);border-radius:999px;background:#ffffffb8;box-shadow:0 6px 16px #0f172a0f;padding:4px}.drawing-toolbar-toggle{justify-content:center;width:28px;height:24px;min-height:24px;border-color:transparent;background:transparent;box-shadow:none;color:#94a3b8;cursor:pointer;opacity:.58;padding:0}.drawing-toolbar-toggle:hover{border-color:#0f172a1f;background:#ffffffd1;box-shadow:0 6px 16px #0f172a0f;color:#334155;opacity:1}.drawing-toolbar-dock:has(.drawing-toolbar) .drawing-tool-palette,.drawing-toolbar{background:#fffffff0;box-shadow:0 10px 24px #0f172a1a}.drawing-tool-palette button,.drawing-toolbar button{display:inline-flex;align-items:center;justify-content:center;width:28px;height:26px;border:0;border-radius:999px;background:transparent;color:#334155;padding:0}.drawing-tool-palette button:hover,.drawing-toolbar button:hover{background:#e0f2fe;color:#075985}.drawing-tool-palette button.active{background:#111827;color:#fff}.drawing-toolbar{color:#075985;padding-left:10px}.drawing-toolbar button:disabled{opacity:.45;cursor:not-allowed}.drawing-toolbar span{min-width:28px;font-size:12px;font-weight:900;white-space:nowrap}.selection-toolbar{position:absolute;left:50%;bottom:24px;z-index:4;display:inline-flex;align-items:center;gap:6px;min-height:36px;transform:translate(-50%);border:1px solid rgba(15,23,42,.12);border-radius:999px;background:#fffffff0;padding:5px 7px 5px 12px}.selection-toolbar span{color:#334155;font-size:12px;font-weight:900;white-space:nowrap}.selection-toolbar button{display:inline-flex;align-items:center;justify-content:center;width:28px;height:26px;border:0;border-radius:999px;background:#f1f5f9;color:#0f172a}.selection-toolbar button:hover{background:#e0f2fe;color:#075985}.selection-toolbar button.active{background:#111827;color:#fff}.selection-toolbar button:disabled{opacity:.42;cursor:not-allowed}.preview-view-toggle{display:grid;grid-template-columns:repeat(2,1fr);gap:0;width:max-content;min-width:148px;overflow:hidden;border:1px solid #cbd5e1;border-radius:7px;background:#f8fafc}.preview-view-toggle button{min-width:0;min-height:32px;border:0;border-radius:0;background:transparent;font-size:12px;padding:0 12px;white-space:nowrap}.preview-view-switch{display:none}.board-stage{display:grid;place-items:center;position:relative;min-height:0;overflow:hidden;padding:8px 0;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;--board-chrome-shift-y: 0px}.board-stage>svg{width:auto;height:100%;max-width:100%;max-height:100%;aspect-ratio:9 / 16;border-radius:8px;cursor:default;touch-action:pan-y;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;transform:translateY(var(--board-chrome-shift-y))}.board-stage>svg.over-object{cursor:grab}.board-stage>svg.dragging{cursor:grabbing}.board-stage>svg.drawing-mode{cursor:crosshair;touch-action:none}.board-stage>svg.dragging{touch-action:none}.board-stage>svg.drawing-mode *{cursor:crosshair}.deck-interactive-layer,.deck-hit-area,.component-ghost-layer{pointer-events:none}.component-ghost-layer path{opacity:.34;stroke-dasharray:6 5}.deck-touch-target{cursor:default;touch-action:none}.deck-orientation-label{pointer-events:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.board-stage>svg.drawing-mode .deck-touch-target{cursor:crosshair}.drawing-draft-layer{pointer-events:none}.drawing-draft-layer circle.snapped{fill:#f97316;stroke-width:1.8}.board-transform-handles{opacity:0;pointer-events:none;transition:opacity .14s ease}.board-transform-handles.visible{opacity:1;pointer-events:auto}.custom-point-handles,.custom-curve-helpers{pointer-events:none}.custom-curve-helpers path{stroke:#38bdf8;stroke-width:1.2;stroke-dasharray:5 5;opacity:.7}.custom-point-handle{cursor:move;pointer-events:auto}.custom-point-handle .handle-hit-area{fill:transparent}.custom-point-handle circle:not(.handle-hit-area){fill:#38bdf8;stroke:#fff;stroke-width:1.4;vector-effect:non-scaling-stroke}.custom-point-handle.control circle:not(.handle-hit-area){fill:#fff;stroke:#38bdf8;stroke-width:2}.custom-point-handle.active circle:not(.handle-hit-area){fill:#f97316}.board-transform-handle{cursor:grab;outline:none;opacity:.68;transition:opacity .14s ease}.board-transform-handle:hover,.board-transform-handles.dragging .board-transform-handle,.board-transform-handle:active{opacity:1;cursor:grabbing}.board-transform-handle circle{fill:#fff;stroke:#f97316;stroke-width:2;vector-effect:non-scaling-stroke}.board-transform-handle .handle-hit-area{fill:transparent;stroke:transparent}.board-transform-handle path{fill:none;stroke:#f97316;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;vector-effect:non-scaling-stroke}.board-resize-handle{cursor:grab;outline:none}.board-resize-handle.horizontal{cursor:ew-resize}.board-resize-handle.vertical{cursor:ns-resize}.board-resize-handle .handle-hit-area{fill:transparent;stroke:transparent}.board-resize-handle rect:not(.handle-hit-area){fill:#fff;stroke:#f97316;stroke-width:1.8;vector-effect:non-scaling-stroke}.selected-object-bounds{fill:none;stroke:#f97316;stroke-width:1.6;stroke-dasharray:6 5;pointer-events:none}.selected-split-line{pointer-events:none}.selected-split-line path{stroke:#f97316;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:7 5;filter:drop-shadow(0 0 3px rgba(15,23,42,.48))}.alignment-guide-line{stroke:#38bdf8;stroke-width:.9;stroke-dasharray:8 7;opacity:.44;pointer-events:none}.alignment-guide-line.active{opacity:.9;stroke-width:1.4}.component-inspector-panel{min-height:0}.panel-title{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.panel-title .icon-text{flex:0 0 auto}.component-editor-main .panel-title{align-items:flex-end}.component-editor-main .panel-title h2{display:inline-flex;align-items:center;gap:6px}.component-count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;border-radius:999px;background:#e2e8f0;color:#475569;padding:0 6px;font-size:11px;font-weight:850;line-height:1}.clear-components-button{flex:0 0 auto;min-height:28px;border:1px solid #cbd5e1;border-radius:7px;background:#fff;color:#475569;padding:0 9px;font-size:12px;font-weight:850}.clear-components-button:hover,.clear-components-button:focus-visible{border-color:#ef4444;background:#fee2e2;color:#b91c1c}.clear-components-button.confirming{border-color:#ef4444;background:#fee2e2;color:#b91c1c}.component-editor{display:grid;grid-template-rows:minmax(0,1fr) auto;gap:12px;height:100%;min-width:0;min-height:0}.component-editor-main{display:flex;flex-direction:column;gap:12px;min-width:0;min-height:0;overflow:hidden;overflow-x:hidden;padding-right:2px}.component-editor .panel-title .icon-text:disabled{opacity:.48;cursor:not-allowed}.component-list{display:grid;align-content:start;gap:8px;flex:0 1 auto;max-height:192px;min-height:0;overflow:auto;overflow-x:hidden;padding-right:2px}.component-list button{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;min-height:42px;border:1px solid #cbd5e1;border-radius:7px;background:#fff;color:#27364a;padding:7px 9px;text-align:left}.component-list button.active{border-color:#111827;box-shadow:inset 0 0 0 1px #111827}.component-list span{min-width:0;font-size:13px;font-weight:850;overflow-wrap:anywhere}.component-list b{border-radius:999px;background:#e2e8f0;color:#475569;padding:3px 7px;font-size:10px;font-weight:850}.empty-component-list{display:grid;gap:5px;border:1px dashed #cbd5e1;border-radius:7px;background:#f8fafc;color:#64748b;padding:12px;font-size:13px;font-weight:750;line-height:1.35}.empty-component-list strong{color:#334155;font-size:13px;font-weight:850}.empty-component-list span{font-weight:650}.component-library{padding-bottom:10px}.component-library>label{display:block;margin-bottom:8px;color:#334155;font-size:13px;font-weight:800}.component-library-groups{display:grid;gap:10px}.component-library-group{display:grid;gap:6px}.component-group-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;min-height:24px;border:0;background:transparent;padding:0;text-align:left}.component-group-toggle span{color:#94a3b8;font-size:11px;font-weight:800}.component-group-toggle svg{color:#94a3b8;flex:0 0 auto}.component-chip-list{display:flex;flex-wrap:wrap;gap:6px;align-items:flex-start}.component-chip-list button{flex:0 1 auto;min-height:28px;min-width:0;border:1px solid #dbe2ea;border-radius:999px;background:#f8fafc;color:#475569;padding:0 9px;font-size:12px;font-weight:800;white-space:nowrap;width:max-content;max-width:100%}.component-chip-list button:hover{border-color:#94a3b8;background:#fff;color:#111827}.object-inspector{display:grid;align-content:start;gap:12px;flex:1 1 auto;min-width:0;min-height:0;overflow:auto;overflow-x:hidden}.object-inspector .control-grid.compact{gap:7px}.object-inspector .number-input span{margin-bottom:4px;color:#64748b;font-size:11px;font-weight:800}.object-inspector .number-input input,.object-inspector select{min-height:32px;border-radius:6px;padding:0 8px;font-size:12px}.object-inspector .range-row{grid-template-columns:64px minmax(0,1fr) 30px;gap:8px;margin-top:8px}.object-inspector .range-row span{color:#64748b;font-size:11px;font-weight:800}.object-inspector .range-row b{font-size:11px;font-weight:850}.object-inspector .preset-actions{gap:6px;margin-bottom:8px}.object-inspector .preset-actions>span{color:#64748b;font-size:11px}.object-inspector .preset-chip-list{gap:6px}.object-inspector .preset-chip-list button{min-height:28px;border-color:#dbe2ea;border-radius:999px;background:#f8fafc;color:#475569;padding:0 9px;font-size:12px;font-weight:800}.object-inspector .preset-chip-list button:hover{border-color:#94a3b8;background:#fff;color:#111827}.component-color-section .color-row{margin-top:0}.component-color-section{margin:2px 0 8px}.inspector-actions{display:flex;gap:6px}.shuffle-button{min-height:34px;border:1px solid #cbd5e1;border-radius:7px;background:#f8fafc;color:#27364a;padding:0 10px;font-size:12px;font-weight:850}.shuffle-button:hover{border-color:#111827}.icon-only.danger{color:#b91c1c}.icon-only:disabled{opacity:.45;cursor:not-allowed}.control-grid.compact{grid-template-columns:repeat(3,minmax(0,1fr));margin-top:0}.transform-grid .number-input{min-width:0}.transform-grid .number-input span{height:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.build-guide{display:grid;gap:8px;border-top:1px solid #dbe2ea;padding-top:10px}.build-guide h2{margin:0;color:#111827;font-size:14px;font-weight:850}.guide-summary{display:flex;align-items:center;justify-content:flex-end;gap:10px;color:#64748b;font-size:12px;font-weight:700}.guide-summary span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.guide-summary b{flex:0 0 auto;color:#94a3b8;padding:0;font-size:11px;font-weight:700}.build-guide section{display:grid;gap:8px}.build-guide h3{margin:0;color:#334155;font-size:13px}.tool-list{display:flex;flex-wrap:wrap;gap:6px}.tool-list span{border-radius:999px;background:#e2e8f0;color:#27364a;padding:5px 8px;font-size:11px;font-weight:800}.build-guide ol,.build-guide ul{display:grid;gap:7px;margin:0;padding-left:18px;color:#475569;font-size:12px;line-height:1.45}.export-panel{display:flex;flex:0 0 auto;align-items:center;justify-content:flex-end;gap:8px;background:#ffffffd1;border:1px solid rgba(124,139,159,.28);border-radius:8px;box-shadow:0 18px 46px #202d4614;padding:10px}.export-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;display:flex;align-items:center;justify-content:center;background:#0f172a61;padding:18px}.export-modal{display:grid;gap:13px;width:min(560px,100%);max-height:calc(100vh - 36px);overflow:auto;border:1px solid rgba(124,139,159,.32);border-radius:10px;background:#fff;box-shadow:0 24px 70px #0f172a3d;padding:16px}.pdf-modal-body{display:grid;gap:12px}.pdf-modal-section{display:grid;gap:7px}.pdf-section-label{color:#64748b;font-size:11px;font-weight:850;letter-spacing:0;line-height:1.2}.share-modal{width:min(460px,100%)}.template-confirm-modal{width:min(420px,100%)}.template-confirm-copy{margin:0;color:#475569;font-size:13px;font-weight:700;line-height:1.55}.export-modal-header,.export-modal-actions{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.export-modal-actions{align-items:center;justify-content:flex-end}.export-modal-actions button,.icon-only{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:34px;border:1px solid #cbd5e1;border-radius:7px;background:#f8fafc;color:#27364a;padding:0 12px;font-size:13px;font-weight:800}.icon-only{width:34px;padding:0}.export-modal-actions .primary{border-color:#111827;background:#111827;color:#fff}.export-modal-actions .danger-primary{border-color:#b91c1c;background:#b91c1c}.export-mode{min-width:0}.pdf-template-modes{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.pdf-template-modes button{min-height:36px;border:1px solid #cbd5e1;border-radius:7px;background:#f8fafc;color:#27364a;padding:0 8px;font-size:11px;font-weight:750;line-height:1.2}.pdf-template-modes button.active{border-color:#111827;background:#111827;color:#fff}.check-grid{display:grid;grid-template-columns:1.35fr .9fr .85fr;gap:8px}.check-item{display:grid;gap:4px;border:1px solid #d6dee8;border-radius:7px;background:#f8fafc;padding:9px}.check-item span{color:#64748b;font-size:11px;font-weight:800}.check-item strong{color:#172033;font-size:12px;line-height:1.25}.check-item em{color:#64748b;font-size:11px;font-style:normal;font-weight:750;line-height:1.2}.check-item.good{border-color:#86efac;background:#f0fdf4}.pdf-summary-strip{display:flex;flex-wrap:wrap;gap:6px}.pdf-summary-strip span{border-radius:999px;background:#f1f5f9;color:#475569;padding:5px 8px;font-size:11px;font-weight:800;line-height:1.2}.export-alerts{display:grid;gap:6px}.export-alert{border-radius:7px;background:#f1f5f9;color:#475569;padding:7px 10px;font-size:12px;font-weight:750;line-height:1.35}.export-alert.important{background:#ffedd5;color:#9a3412}.share-preview{display:grid;place-items:center;border:1px solid #d6dee8;border-radius:8px;background:#111827;padding:10px}.share-preview img{display:block;width:min(100%,320px);aspect-ratio:4 / 5;border-radius:6px;object-fit:cover}.share-preview-loading{display:grid;place-items:center;width:min(100%,320px);aspect-ratio:4 / 5;border-radius:6px;background:#f8fafc;color:#64748b;font-size:13px;font-weight:800}.share-save-hint{min-height:18px;margin:-4px 0 0;color:#64748b;font-size:12px;font-weight:750;line-height:1.4;text-align:center}.layer-toggles{display:flex;flex-wrap:wrap;gap:8px}.layer-toggles label{display:inline-flex;align-items:center;gap:6px;border:1px solid #cbd5e1;border-radius:999px;background:#f8fafc;color:#334155;padding:6px 9px;font-size:12px;font-weight:800}.layer-toggles input{width:14px;height:14px;accent-color:#111827}.export-actions{display:flex;flex-wrap:nowrap;gap:6px;justify-content:flex-end;width:100%}.export-actions button{display:inline-flex;align-items:center;justify-content:center;flex:0 1 auto;gap:6px;min-height:34px;padding:0 10px;white-space:nowrap}.export-actions .primary{border-color:#111827;background:#111827;color:#fff}.cutting-guide-inline-trigger{width:fit-content;min-height:0;border:0;background:transparent;color:#64748b;padding:0;font-size:13px;font-weight:800}.cutting-guide-inline-trigger:hover{color:#111827}.cutting-guide-disclosure{border-top:1px solid #e2e8f0;padding-top:12px}.cutting-guide-content{display:grid;gap:14px;margin-top:12px;color:#334155}.cutting-guide-content h3{margin:0 0 8px;color:#111827;font-size:13px}.cutting-guide-content ol,.cutting-guide-content ul{margin:0;padding-left:20px;font-size:14px;line-height:1.7}@media(max-width:1100px){.app-shell{gap:10px;padding:10px}.controls,.component-inspector-panel{padding:12px}.main-column{gap:10px}.preview-shell{padding:12px}}@media(min-width:761px)and (max-height:760px){.app-shell{gap:8px;padding:8px}.main-column{gap:8px}.preview-shell{padding:10px}.export-panel{padding:7px}.export-actions{gap:5px}.export-actions button{min-height:30px;gap:5px;padding:0 8px;font-size:12px}.export-actions svg{width:14px;height:14px}.preview-header{align-items:center}.preview-header .eyebrow{margin-bottom:2px;font-size:10px}.preview-header h2{font-size:18px}.board-stage{padding:4px 0}.drawing-toolbar-dock{top:10px;gap:5px}.drawing-toolbar-dock.collapsed{top:8px}.drawing-tool-palette,.drawing-toolbar{gap:3px;min-height:30px;padding:3px}.drawing-toolbar{padding-left:8px}.drawing-tool-palette button,.drawing-toolbar button,.selection-toolbar button{width:26px;height:24px}.drawing-tool-palette svg,.drawing-toolbar svg,.selection-toolbar svg{width:14px;height:14px}.drawing-toolbar span,.selection-toolbar span{font-size:11px}.selection-toolbar{bottom:12px;gap:4px;min-height:32px;max-width:calc(100% - 20px);overflow-x:auto;padding:4px 5px 4px 10px}}@media(min-width:761px)and (max-height:660px){.app-shell{gap:6px;padding:6px}.main-column{gap:6px}.preview-shell{padding:8px}.export-panel{padding:5px}.export-actions{gap:4px}.export-actions button{min-height:28px;gap:4px;padding:0 7px;font-size:11px}.export-actions svg{width:13px;height:13px}.preview-header .eyebrow{display:none}.preview-header h2{font-size:16px}.preview-view-toggle button{min-height:28px;padding:0 8px;font-size:12px}.board-stage{padding:2px 0}.drawing-toolbar-dock{top:8px;gap:4px}.drawing-toolbar-dock.collapsed{top:6px}.drawing-tool-palette,.drawing-toolbar{gap:2px;min-height:28px;padding:2px}.drawing-toolbar{padding-left:7px}.drawing-tool-palette button,.drawing-toolbar button,.selection-toolbar button{width:24px;height:22px}.drawing-toolbar-toggle{width:24px;height:22px;min-height:22px}.drawing-toolbar span,.selection-toolbar span{font-size:10px}.selection-toolbar{bottom:8px;gap:3px;min-height:28px;padding:3px 4px 3px 8px}}@media(max-width:760px){body{background:#f8fafc}.mobile-shell{display:grid;grid-template-rows:auto minmax(0,1fr) auto;width:100%;min-height:100dvh;background:#f8fafc;overflow:hidden}.mobile-titlebar{display:flex;align-items:center;min-height:60px;background:#fff;padding:8px 14px}.mobile-titlebar .brand-block{width:100%;gap:10px;border-bottom:0;padding-bottom:0}.mobile-titlebar .mark{width:40px;height:40px;font-size:21px}.mobile-titlebar h1{font-size:19px}.mobile-titlebar .eyebrow{margin-bottom:2px;font-size:11px}.mobile-workspace{display:grid;grid-template-rows:minmax(0,1fr);position:relative;min-height:0;background:#fff;--mobile-safe-bottom: env(safe-area-inset-bottom, 0px);--mobile-toolbar-space: calc(60px + var(--mobile-safe-bottom))}.mobile-workspace:fullscreen,.mobile-workspace.fullscreen-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;display:grid;grid-template-rows:minmax(0,1fr);width:100%;height:100dvh;background:#fff}.mobile-editor-section{position:relative;min-height:0;background:#fff;padding-bottom:var(--mobile-toolbar-space)}.mobile-editor-section .preview-shell{height:100%;min-height:min(60dvh,580px);border:0;border-radius:0;box-shadow:none;background:#fff;padding:0}.mobile-workspace:fullscreen .preview-shell,.mobile-workspace.fullscreen-overlay .preview-shell{min-height:0}.mobile-workspace:fullscreen .mobile-editor-section,.mobile-workspace.fullscreen-overlay .mobile-editor-section{padding-bottom:var(--mobile-toolbar-space)}.preview-shell.compact-chrome{grid-template-rows:1fr}.preview-shell.compact-chrome .preview-header{display:none}.preview-shell.compact-chrome .board-stage{padding:8px 0;--board-chrome-shift-y: 12px}.preview-shell.compact-chrome .board-stage>svg{height:94%;max-height:94%}.mobile-fullscreen-button{position:absolute;top:14px;right:14px;z-index:8;width:38px;min-height:38px;border-color:#0f172a1a;border-radius:999px;background:#ffffffad;color:#64748b;box-shadow:none;opacity:.72;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.mobile-fullscreen-button:hover,.mobile-fullscreen-button:focus-visible{border-color:#0f172a24;background:#ffffffe6;color:#111827;opacity:1}.mobile-fullscreen-button svg{width:18px;height:18px}.mobile-toolbar{display:grid;grid-template-columns:repeat(auto-fit,minmax(0,1fr));background:#fff;padding:6px 4px max(6px,var(--mobile-safe-bottom))}.mobile-workspace .mobile-toolbar{position:absolute;right:0;bottom:0;left:0;z-index:9}.mobile-shell.sheet-open .mobile-titlebar,.mobile-shell.sheet-open .mobile-workspace,.mobile-shell.sheet-open .mobile-export-section{touch-action:none;overscroll-behavior:none}.mobile-workspace:fullscreen .mobile-toolbar,.mobile-workspace.fullscreen-overlay .mobile-toolbar{position:absolute;right:0;bottom:0;left:0;z-index:9}.mobile-toolbar button{display:grid;place-items:center;gap:2px;min-width:0;min-height:48px;border:0;border-radius:6px;background:transparent;color:#64748b;padding:3px 2px;font-size:11px;font-weight:750}.mobile-toolbar button.active{background:#eef2f7;color:#111827}.mobile-toolbar span{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-toolbar svg{width:19px;height:19px;stroke-width:2}.mobile-export-section{background:#fff;padding:2px 8px 12px}.mobile-export-section .build-guide{margin-top:14px;border-top:0;padding:14px 2px 12px}.mobile-export-section .build-guide h2{font-size:15px}.mobile-export-section .build-guide h3{font-size:13px}.mobile-export-section .build-guide ol,.mobile-export-section .build-guide ul{gap:8px;font-size:13px;line-height:1.6}.mobile-export-section .export-panel{border:0;border-radius:0;box-shadow:none;background:transparent;padding:0}.mobile-export-section .export-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.mobile-export-section .export-actions button{min-width:0;min-height:44px;border-color:#dbe2ea;background:#f8fafc;color:#475569;padding:0 6px;font-size:13px;font-weight:800;line-height:1.1}.mobile-export-section .export-actions .pdf-action{grid-column:1 / -1;grid-row:1;min-height:44px;border-color:#111827;background:#111827;color:#fff;font-size:13px}.mobile-export-section .export-actions svg{flex:0 0 auto;width:16px;height:16px}.mobile-panel-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;display:flex;align-items:flex-end;background:#0f172a2e}.mobile-panel{display:grid;grid-template-rows:auto auto minmax(0,1fr);width:100%;max-height:min(72dvh,620px);border:1px solid rgba(15,23,42,.08);border-bottom:0;border-radius:12px 12px 0 0;background:#fff;box-shadow:0 -10px 30px #0f172a1f;padding:7px 14px max(12px,env(safe-area-inset-bottom))}.mobile-sheet-handle{justify-self:center;width:42px;height:4px;border-radius:999px;background:#cbd5e1}.mobile-panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:44px;border-bottom:1px solid rgba(226,232,240,.86)}.mobile-panel-header h2{color:#111827;font-size:18px;font-weight:850}.mobile-panel-header .icon-only{width:40px;min-height:40px}.mobile-panel-body{min-height:0;overflow:auto;overscroll-behavior:contain;touch-action:pan-y;-webkit-overflow-scrolling:touch;padding:10px 0 4px;scrollbar-width:none}.mobile-panel-body::-webkit-scrollbar{display:none}.mobile-panel-body .panel{border:0;border-radius:0;box-shadow:none;background:transparent}.mobile-panel-body .component-inspector-panel{padding:0}.mobile-panel-body .control-group:first-child{margin-top:0}.mobile-panel-body .control-group{margin-top:14px}.mobile-panel-body .mobile-board-settings{display:grid;gap:16px}.mobile-panel-body .deck-summary-control>label{display:none}.mobile-panel-body .template-library .template-library-toggle{display:none}.mobile-panel-body .template-chip-list{display:grid;grid-template-columns:1fr;gap:8px;min-height:168px;align-content:start;margin-top:0}.mobile-panel-body .template-chip-list button{display:grid;grid-template-columns:minmax(0,1fr);align-items:center;justify-content:flex-start;width:100%;min-height:44px;border-color:#cbd5e1;border-radius:7px;background:#fff;color:#27364a;padding:9px 11px;text-align:left}.mobile-panel-body .template-chip-list button span{font-size:14px;font-weight:850}.mobile-panel-body .deck-summary-header.open{display:none}.mobile-panel-body .deck-summary-editor{gap:14px;margin-top:0;border:0;border-radius:0;background:transparent;padding:0}.mobile-panel-body .deck-editor-row{grid-template-columns:48px minmax(0,1fr);gap:12px}.mobile-panel-body .compact-deck-segmented button{min-height:38px;font-size:13px}.mobile-panel-body .preset-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.mobile-panel-body .preset-grid button{min-height:40px;font-size:13px}.mobile-panel-body .deck-size-fields{gap:12px}.mobile-panel-body .deck-custom-size-grid{gap:8px;padding-top:12px}.mobile-panel-body .deck-custom-size-grid .number-input input{font-size:16px}.mobile-panel-body .component-library{padding-bottom:0}.mobile-panel-body .component-library>label{display:none}.mobile-panel-body .component-library-groups{gap:8px}.mobile-panel-body .component-library-group{gap:7px}.mobile-panel-body .component-editor{gap:10px}.mobile-panel-body .component-list-panel{display:grid;gap:10px;align-content:start;min-height:168px}.mobile-panel-body .component-list-panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:34px}.mobile-panel-body .component-list-panel-header>span{color:#64748b;font-size:12px;font-weight:800}.mobile-panel-body .panel-title{margin-bottom:2px}.mobile-panel-body .template-library-toggle,.mobile-panel-body .component-group-toggle{min-height:42px}.mobile-panel-body .component-group-toggle{border-radius:7px;background:#f8fafc;padding:0 10px}.mobile-panel-body .component-group-toggle span{color:#475569;font-size:13px;font-weight:750}.mobile-panel-body .component-chip-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:7px;padding-top:1px}.mobile-panel-body .component-chip-list button,.mobile-panel-body .template-chip-list button,.mobile-panel-body .preset-chip-list button{min-height:40px;border-radius:7px;padding-inline:12px;font-size:13px}.mobile-panel-body .component-chip-list button{width:100%;justify-content:center;border-color:#e2e8f0;border-radius:7px;background:#fff;color:#334155;font-weight:700;white-space:nowrap}.mobile-panel-body .control-group>label,.mobile-panel-body .inline-label label,.mobile-panel-body .template-library-toggle span,.mobile-panel-body .component-library>label{font-size:14px}.mobile-panel-body .deck-summary-copy,.mobile-panel-body .number-input input,.mobile-panel-body select,.mobile-panel-body .component-list span{font-size:14px}.mobile-panel-body .number-input input,.mobile-panel-body select{min-height:38px}.mobile-panel-body .number-input span,.mobile-panel-body .deck-editor-row>span,.mobile-panel-body .component-group-toggle span{font-size:12px}.mobile-panel-body .component-list{max-height:none;gap:8px}.mobile-panel-body .component-list button{min-height:44px;border-radius:7px;padding:9px 11px}.mobile-panel-body .empty-component-list{border-style:solid;background:#f8fafc;padding:14px;font-size:14px}.mobile-panel-body .component-editor-main{overflow:visible}.mobile-panel-body .control-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.mobile-panel-body .transform-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.mobile-panel-body .color-row{grid-template-columns:42px minmax(0,1fr) 32px;gap:10px}.mobile-panel-body .swatches{gap:6px}.mobile-panel-body .swatches button{width:24px;height:24px;border-width:2px}.mobile-panel-body .color-row input[type=color]{width:32px;height:30px}.export-panel{flex-direction:column;align-items:stretch;justify-content:flex-start}.drawing-toolbar-dock{top:14px;max-width:calc(100% - 24px);overflow-x:auto;padding-bottom:2px}.drawing-toolbar-dock.muted{opacity:.28;pointer-events:none}.drawing-tool-palette,.drawing-toolbar{gap:5px;min-height:38px;box-shadow:none;padding:5px}.drawing-tool-palette button,.drawing-toolbar button{width:32px;height:30px}.drawing-tool-palette svg,.drawing-toolbar svg{width:16px;height:16px}.selection-toolbar{bottom:18px;max-width:calc(100% - 20px);overflow-x:auto}.export-modal-backdrop{align-items:flex-end;padding:0}.export-modal{width:100%;max-height:86dvh;border-radius:10px 10px 0 0;padding:8px 14px max(14px,env(safe-area-inset-bottom))}.pdf-template-modes,.check-grid{grid-template-columns:repeat(2,minmax(0,1fr))}input:not([type=range]):not([type=color]),select,textarea,.mobile-panel-body .number-input input,.mobile-panel-body select,.object-inspector .number-input input,.object-inspector select{font-size:16px}}
