:root{font-family:Avenir Next,Nunito Sans,Segoe UI,sans-serif;line-height:1.35;font-weight:500;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--ink: #1f2527;--muted: #6a7478;--paper: #f3efe8;--panel: #fffdf9;--border: #d9d1c5;--shadow: 0 18px 45px rgba(38, 33, 24, .12);--accent: #245a58}*{box-sizing:border-box}.app-shell,.app-shell *{-webkit-user-select:none;user-select:none}input,textarea,select,[contenteditable=true]{-webkit-user-select:text;user-select:text}html,body{height:100%}body{margin:0;min-width:320px;color:var(--ink);overflow:hidden;background:radial-gradient(circle at 14% 12%,#f8dfbf 0,transparent 36%),radial-gradient(circle at 82% 0%,#c4d9df 0,transparent 32%),linear-gradient(180deg,#f4eee2,#ece7df)}#root{height:100%}.app-shell{height:100%;max-width:1400px;margin:0 auto;padding:.55rem .85rem .7rem;display:grid;grid-template-rows:auto auto minmax(0,1fr);gap:.42rem}.app-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.45rem;flex-wrap:nowrap;margin-bottom:0}.mobile-header-left{display:none;position:relative;flex:none}.mobile-file-status{display:none;margin:0;font-size:.74rem;color:#4f5a5e;white-space:nowrap;text-overflow:ellipsis;overflow:hidden;max-width:min(38vw,11rem);text-align:right}.header-main{display:flex;align-items:center;gap:.55rem;min-width:0;flex:1 1 auto}.header-controls{display:flex;flex-direction:column;align-items:flex-end;gap:.28rem;min-width:0}.app-logo{display:block;width:auto;height:clamp(2.1rem,5.8vw,3.4rem);max-width:none;object-fit:contain;object-position:center;flex:none}.eyebrow{margin:0;text-transform:uppercase;letter-spacing:.08em;font-size:.74rem;color:var(--muted)}h1{margin:0;font-size:clamp(1.1rem,2.2vw,1.55rem)}.file-status{margin:0;font-size:.8rem;color:#4f5a5e;white-space:normal;text-align:right}.file-status-dirty{color:#8a2a18;font-weight:600}.header-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:.38rem;margin-left:0}.mobile-actions-menu{position:absolute;top:calc(100% + .35rem);left:0;z-index:20;min-width:min(82vw,16rem);display:grid;gap:.3rem;padding:.42rem;border:1px solid var(--border);border-radius:14px;background:var(--panel);box-shadow:var(--shadow)}.mobile-actions-menu .header-action{justify-content:flex-start;width:100%}.mobile-actions-file{border-top:1px solid #ded5ca;margin-top:.2rem;padding-top:.4rem;font-size:.78rem;color:#4f5a5e}.mobile-view-tabs{display:none}.mobile-view-tab{text-align:center;padding:.35rem .4rem;border-radius:12px;font-size:.8rem}.mobile-view-tab.active{background:#245a58;border-color:#245a58;color:#f6f3ec}.mobile-edit-rail{display:none}.mobile-edit-group{display:grid;gap:.32rem}.mobile-edit-separator{display:block;width:100%;height:1px;background:#d8cec2;margin:.08rem 0}.compact-color-wrap{position:relative}.compact-color-toggle{display:grid;gap:.12rem;justify-items:center;align-content:center;width:2.12rem;height:2.12rem;padding:0}.compact-color-label{font-size:.56rem;letter-spacing:.06em;line-height:1}.compact-color-chip{width:.75rem;height:.75rem;border:1px solid #5d5e61;border-radius:4px}.compact-palette-menu{left:calc(100% + .35rem);top:0}.header-action{display:inline-flex;align-items:center;gap:.32rem}.header-action-icon{width:.9rem;height:.9rem;stroke-width:2.1;flex:none}.metadata-inline-action{border:none;background:transparent;color:#245a58;font:inherit;font-size:.78rem;cursor:pointer;margin-left:.42rem;padding:0;text-decoration:underline;text-underline-offset:.11rem}.metadata-inline-action:hover{color:#1f4a48}.hidden-file-input{display:none}.action{border:1px solid var(--border);border-radius:999px;padding:.38rem .72rem;background:var(--panel);color:var(--ink);font:inherit;font-size:.88rem;cursor:pointer}.action:hover{border-color:#bdb3a4}.action:disabled{cursor:not-allowed;color:#8f8b85;border-color:#d5ccc0}@media(hover:hover)and (pointer:fine){.action[title],.metadata-inline-action[title]{position:relative;--tooltip-bg: rgba(21, 27, 31, .96);--tooltip-left: 50%;--tooltip-top: auto;--tooltip-bottom: calc(100% + .45rem) ;--tooltip-transform-hidden: translate(-50%, 4px);--tooltip-transform-visible: translate(-50%, 0);--tooltip-arrow-left: 50%;--tooltip-arrow-top: auto;--tooltip-arrow-bottom: calc(100% + .2rem) ;--tooltip-arrow-transform-hidden: translate(-50%, 4px);--tooltip-arrow-transform-visible: translate(-50%, 0);--tooltip-arrow-border-top: 5px solid var(--tooltip-bg);--tooltip-arrow-border-right: 5px solid transparent;--tooltip-arrow-border-bottom: 0 solid transparent;--tooltip-arrow-border-left: 5px solid transparent}.action[title]:before,.metadata-inline-action[title]:before,.action[title]:after,.metadata-inline-action[title]:after{opacity:0;pointer-events:none;transition:opacity .14s ease,transform .14s ease;z-index:80}.action[title]:before,.metadata-inline-action[title]:before{content:"";position:absolute;left:var(--tooltip-arrow-left);top:var(--tooltip-arrow-top);bottom:var(--tooltip-arrow-bottom);transform:var(--tooltip-arrow-transform-hidden);border-top:var(--tooltip-arrow-border-top);border-right:var(--tooltip-arrow-border-right);border-bottom:var(--tooltip-arrow-border-bottom);border-left:var(--tooltip-arrow-border-left)}.action[title]:after,.metadata-inline-action[title]:after{content:attr(title);position:absolute;left:var(--tooltip-left);top:var(--tooltip-top);bottom:var(--tooltip-bottom);transform:var(--tooltip-transform-hidden);white-space:nowrap;max-width:min(80vw,28rem);overflow:hidden;text-overflow:ellipsis;padding:.25rem .45rem;border-radius:7px;background:var(--tooltip-bg);color:#f7f6f2;font-size:.72rem;line-height:1.2;font-weight:500}.app-header .action[title],.app-header .metadata-inline-action[title]{--tooltip-top: calc(100% + .45rem) ;--tooltip-bottom: auto;--tooltip-transform-hidden: translate(-50%, -4px);--tooltip-transform-visible: translate(-50%, 0);--tooltip-arrow-top: calc(100% + .2rem) ;--tooltip-arrow-bottom: auto;--tooltip-arrow-transform-hidden: translate(-50%, -4px);--tooltip-arrow-transform-visible: translate(-50%, 0);--tooltip-arrow-border-top: 0 solid transparent;--tooltip-arrow-border-right: 5px solid transparent;--tooltip-arrow-border-bottom: 5px solid var(--tooltip-bg);--tooltip-arrow-border-left: 5px solid transparent}.mobile-edit-rail .action[title]{--tooltip-left: calc(100% + .45rem) ;--tooltip-top: 50%;--tooltip-bottom: auto;--tooltip-transform-hidden: translate(-4px, -50%);--tooltip-transform-visible: translate(0, -50%);--tooltip-arrow-left: calc(100% + .2rem) ;--tooltip-arrow-top: 50%;--tooltip-arrow-bottom: auto;--tooltip-arrow-transform-hidden: translate(-4px, -50%);--tooltip-arrow-transform-visible: translate(0, -50%);--tooltip-arrow-border-top: 5px solid transparent;--tooltip-arrow-border-right: 5px solid var(--tooltip-bg);--tooltip-arrow-border-bottom: 5px solid transparent;--tooltip-arrow-border-left: 0 solid transparent}.action[title]:hover:before,.action[title]:hover:after,.action[title]:focus-visible:before,.action[title]:focus-visible:after,.metadata-inline-action[title]:hover:before,.metadata-inline-action[title]:hover:after,.metadata-inline-action[title]:focus-visible:before,.metadata-inline-action[title]:focus-visible:after{opacity:1}.action[title]:hover:before,.action[title]:focus-visible:before,.metadata-inline-action[title]:hover:before,.metadata-inline-action[title]:focus-visible:before{transform:var(--tooltip-arrow-transform-visible)}.action[title]:hover:after,.action[title]:focus-visible:after,.metadata-inline-action[title]:hover:after,.metadata-inline-action[title]:focus-visible:after{transform:var(--tooltip-transform-visible)}}.tool-action.active{background:#245a58;border-color:#245a58;color:#f6f3ec}.file-input-label{position:relative;overflow:hidden}.file-input-label input{position:absolute;inset:0;opacity:0;cursor:pointer}.workspace{display:grid;grid-template-columns:minmax(0,1fr);gap:.8rem;height:100%;min-height:0;overflow:hidden}.print-workspace{display:none}.preview-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));grid-auto-rows:minmax(0,1fr);height:100%;align-content:stretch;min-height:0}.preview-with-scrollbar{display:grid;grid-template-columns:minmax(0,1fr);gap:.65rem;align-items:stretch;height:100%;min-height:0}.preview-with-scrollbar.has-canvas.no-report{grid-template-columns:minmax(0,1fr) 38px}.preview-with-scrollbar.has-canvas.has-report{grid-template-columns:minmax(0,1fr) 38px minmax(250px,290px)}.tools-panel{margin-bottom:0;padding:.72rem .85rem;overflow:visible}.toolbar-layout{display:flex;align-items:flex-start;justify-content:space-between;gap:.7rem;flex-wrap:wrap;overflow:visible}.toolbar-side{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;min-width:0;overflow:visible}.toolbar-edit{flex:1 1 560px}.toolbar-view{margin-left:auto;justify-content:flex-end;flex:0 1 auto}.toolbar-group{gap:.38rem}.toolbar-separator{width:1px;height:1.86rem;background:#d8cec2;margin:0 .08rem}.button-strip{display:flex;flex-wrap:wrap;gap:.55rem}.icon-action{width:2.12rem;height:2.12rem;padding:0;border-radius:11px;display:inline-flex;align-items:center;justify-content:center}.tool-icon{width:1.16rem;height:1.16rem;stroke-width:2.15}.view-toggle.active{background:#245a58;border-color:#245a58;color:#f6f3ec}.color-toggle{border-radius:11px;padding:.3rem .52rem;display:inline-flex;align-items:center;gap:.42rem}.color-toggle-label{font-size:.79rem;letter-spacing:.01em}.color-toggle-chip{width:.9rem;height:.9rem;border:1px solid #5d5e61;border-radius:4px;flex:none}.panel{background:var(--panel);border:1px solid var(--border);border-radius:20px;padding:.85rem;box-shadow:var(--shadow)}.panel-title{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:.9rem}.panel-title h2{margin:0;font-size:1rem;letter-spacing:.03em;text-transform:uppercase}.panel-title span{color:var(--muted);font-size:.86rem}.canvas-panel{min-height:0;height:100%;display:flex;flex-direction:column;overflow:hidden}.report-panel{min-height:0;display:flex;flex-direction:column}.report-content{color:#1f2527;font-size:.86rem;display:grid;gap:.48rem;align-content:start;flex:1;min-height:0;overflow:auto;padding-right:.12rem}.report-content p{margin:0}.report-info-list{margin:0;padding:0;display:grid;gap:.18rem}.report-info-row{display:grid;grid-template-columns:max-content max-content;justify-content:start;gap:.32rem;align-items:baseline}.report-info-row dt,.report-info-row dd{margin:0}.report-info-row dt{color:#1f2527}.report-info-row dd{color:#1f2527;font-weight:500}.report-bead-list h3{margin:0 0 .22rem;font-size:.82rem;letter-spacing:.01em;color:#1f2527}.report-color-usage{margin:0}.report-color-grid{display:flex;flex-wrap:wrap;gap:.16rem .68rem;align-items:center}.report-color-row{display:flex;align-items:center;gap:.18rem;min-width:4.95rem}.report-color-count{min-width:2.8rem;text-align:right;color:#1f2527;font-weight:500}.report-color-swatch{width:.95rem;height:.95rem;border:1px solid #566064;border-radius:0;background:#f7f5f0}.report-bead-grid{column-width:2.34rem;column-gap:0}.report-bead-row{display:inline-flex;align-items:center;gap:.06rem;width:100%;margin:0 0 .02rem;break-inside:avoid}.report-bead-count{color:#1f2527;font-weight:500}.empty-pane{min-height:170px;display:flex;align-items:center;justify-content:center;color:var(--muted)}.empty-pane p{margin:0}.draft-panel{min-height:0}.canvas-scroll{display:flex;justify-content:flex-start;align-items:flex-start;overflow-x:auto;overflow-y:auto;flex:1;height:100%;max-height:100%;min-width:0;min-height:0;border:1px dashed #c9c0b4;border-radius:14px;background:var(--paper);padding:.7rem;scrollbar-width:none}.canvas-scroll>.bead-canvas,.canvas-scroll>.bead-preview-canvas{margin-left:auto;margin-right:auto}.canvas-scroll::-webkit-scrollbar:vertical{width:0}.canvas-scroll::-webkit-scrollbar:horizontal{height:8px}.canvas-scroll::-webkit-scrollbar-thumb:horizontal{background:#b7ad9f;border-radius:999px}.shared-scrollbar-panel{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;border:1px solid var(--border);border-radius:12px;background:var(--panel);box-shadow:var(--shadow);padding:.35rem .2rem}.report-split-panel{min-width:0}.views-menu-wrap,.palette-menu-wrap{position:relative}.views-menu{position:absolute;top:calc(100% + .25rem);left:0;min-width:10rem;background:var(--panel);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow);padding:.4rem;display:grid;gap:.25rem;z-index:6}.palette-menu{position:absolute;top:calc(100% + .25rem);left:0;min-width:18.8rem;background:var(--panel);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow);padding:.62rem;z-index:40}.views-menu-item{display:flex;align-items:center;gap:.45rem;font-size:.84rem;color:#2a2f31;padding:.17rem .2rem;border-radius:7px}.views-menu-item:hover{background:#f2eee7}.palette-menu-grid{display:grid;grid-template-columns:repeat(8,minmax(0,1fr));gap:.52rem}.palette-menu-swatch{width:1.82rem;border-radius:5px}.palette-edit-button{width:100%;margin-top:.62rem;justify-content:center}.shared-scrollbar{writing-mode:bt-lr;-webkit-appearance:slider-vertical;width:18px;height:min(100%,720px)}.sidebar{display:grid;align-content:start;gap:.9rem;min-height:0;overflow:auto}.bead-canvas{display:block;cursor:crosshair;touch-action:pan-x pan-y}.bead-preview-canvas{display:block;touch-action:pan-x pan-y}@media(hover:hover)and (pointer:fine){.bead-canvas,.bead-preview-canvas{touch-action:none}}.palette-grid{display:grid;grid-template-columns:repeat(8,minmax(0,1fr));gap:.34rem}.palette-actions{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.55rem}.swatch{border:2px solid transparent;border-radius:6px;aspect-ratio:1;cursor:pointer}.swatch.selected{border-color:var(--accent);transform:translateY(-1px)}.palette-color-picker{position:fixed;left:0;top:0;width:1px;height:1px;opacity:.01}.metadata-section{border-top:1px solid #dfd7cb;padding-top:.45rem;display:grid;gap:.45rem}.metadata-section .panel-title{margin-bottom:.15rem}.metadata-field{display:grid;gap:.24rem;color:#4f5a5e;font-size:.82rem}.metadata-input{border:1px solid var(--border);border-radius:9px;background:#fffefb;color:var(--ink);font:inherit;padding:.38rem .46rem}.metadata-notes{min-height:5.2rem;resize:vertical}.dialog-backdrop{position:fixed;inset:0;background:#18171452;display:grid;place-items:center;padding:1rem;z-index:120}.arrange-dialog{width:min(420px,100%);border-radius:16px}.recent-dialog{width:min(560px,100%)}.help-dialog{width:min(860px,100%);max-height:min(88vh,900px)}.help-content{display:grid;gap:.9rem;color:#30383b;font-size:.9rem;line-height:1.45;max-height:min(66vh,620px);overflow:auto;padding-right:.2rem}.help-section{display:grid;gap:.35rem}.help-section h3{margin:0;font-size:.92rem;letter-spacing:.02em;text-transform:uppercase}.help-content p{margin:0}.help-content ul{margin:0;padding-left:1.1rem;display:grid;gap:.12rem}.help-content li{margin:.14rem 0}.help-content a{color:#245a58}.help-shortcuts-table-wrap{overflow:auto;border:1px solid #d9d1c5;border-radius:10px}.help-shortcuts-table{width:100%;min-width:520px;border-collapse:collapse;font-size:.84rem}.help-shortcuts-table th,.help-shortcuts-table td{text-align:left;vertical-align:top;padding:.42rem .48rem;border-bottom:1px solid #e5ddd2}.help-shortcuts-table thead th{background:#f5f1ea;font-weight:700}.help-shortcuts-table tbody tr:last-child td{border-bottom:none}.recent-empty{margin:0;color:var(--muted);font-size:.92rem}.recent-list{display:grid;gap:.5rem;max-height:min(52vh,420px);overflow:auto;padding-right:.2rem}.recent-item{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.45rem;align-items:center}.recent-open{display:grid;justify-items:start;gap:.1rem;border-radius:12px;padding:.48rem .62rem;text-align:left}.recent-name{color:#212729;font-size:.9rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.recent-date{color:var(--muted);font-size:.76rem}.recent-remove{border-radius:12px;padding:.4rem .62rem}.arrange-form{display:grid;gap:.65rem}.arrange-field{display:grid;gap:.3rem;color:#4f5a5e;font-size:.88rem}.arrange-input{border:1px solid var(--border);border-radius:9px;background:#fffefb;color:var(--ink);font:inherit;padding:.42rem .5rem}.metadata-notes-input{min-height:6.3rem;resize:vertical}.arrange-actions{margin-top:.9rem;display:flex;justify-content:flex-end;gap:.5rem}@media(max-width:1024px){.mobile-view-tabs{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.35rem}.app-shell{grid-template-rows:auto auto auto minmax(0,1fr)}.app-header{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:.35rem;flex-wrap:unset}.mobile-header-left,.mobile-file-status{display:block}.mobile-file-status{max-width:min(40vw,14rem)}.mobile-menu-toggle{width:2.12rem;height:2.12rem}.header-main{justify-content:center;flex:1 1 auto}.header-controls{display:none}.app-logo{height:clamp(1.9rem,5.6vw,2.8rem)}.tools-panel{padding:.52rem}.toolbar-layout{display:flex;align-items:flex-start;justify-content:flex-start;gap:.52rem;flex-wrap:wrap}.toolbar-edit{display:none}.toolbar-view{display:flex;flex:1 1 auto;margin-left:0;justify-content:flex-start;align-content:start;gap:.34rem}.toolbar-view .views-menu-wrap{display:none}.workspace{grid-template-columns:auto minmax(0,1fr);grid-template-rows:minmax(0,1fr);height:100%;min-height:0;overflow:hidden;gap:.5rem}.mobile-edit-rail{display:flex;flex-direction:column;gap:.34rem;align-self:stretch;height:100%;min-height:0;overflow:visible;padding:.52rem .46rem;position:relative;z-index:12}.mobile-edit-group-scroll{flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch}.mobile-edit-group-scroll::-webkit-scrollbar{width:0;height:0}.preview-with-scrollbar{min-width:0;grid-template-columns:1fr;height:100%}.preview-with-scrollbar.has-canvas.no-report{grid-template-columns:1fr}.preview-with-scrollbar.has-canvas.has-report{grid-template-columns:minmax(0,1fr) minmax(220px,280px)}.preview-grid{grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-rows:minmax(0,1fr);min-height:0;height:100%}.preview-grid.single-canvas{grid-template-columns:1fr}.shared-scrollbar-panel{display:none}.sidebar{order:-1;overflow:visible}.canvas-panel{min-height:0}}@media(max-width:500px){.mobile-view-tabs{display:flex;flex-wrap:nowrap;gap:.35rem;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.mobile-view-tabs::-webkit-scrollbar{width:0;height:0}.mobile-view-tab{flex:0 0 auto;white-space:nowrap}.preview-grid{grid-template-columns:1fr;grid-auto-rows:auto;height:auto}.preview-with-scrollbar{grid-template-columns:1fr;height:auto}.preview-with-scrollbar.has-canvas.has-report,.preview-with-scrollbar.has-canvas.no-report{grid-template-columns:1fr}}@media print{@page jbead-default{size:auto;margin:10mm}@page jbead-a4-portrait{size:A4 portrait;margin:10mm}@page jbead-a4-landscape{size:A4 landscape;margin:10mm}@page jbead-letter-portrait{size:Letter portrait;margin:10mm}@page jbead-letter-landscape{size:Letter landscape;margin:10mm}html,body,#root{height:auto;overflow:visible;background:#fff!important}body{margin:0;min-width:0;color:#000;-webkit-print-color-adjust:exact;print-color-adjust:exact;page:jbead-default}.app-shell{page:jbead-default}body.print-page-a4.print-orientation-portrait,body.print-page-a4.print-orientation-portrait .app-shell{page:jbead-a4-portrait}body.print-page-a4.print-orientation-landscape,body.print-page-a4.print-orientation-landscape .app-shell{page:jbead-a4-landscape}body.print-page-letter.print-orientation-portrait,body.print-page-letter.print-orientation-portrait .app-shell{page:jbead-letter-portrait}body.print-page-letter.print-orientation-landscape,body.print-page-letter.print-orientation-landscape .app-shell{page:jbead-letter-landscape}.app-shell{height:auto;max-width:none;margin:0;padding:0;display:block}.app-header{display:none!important;margin:0}.header-actions,.tools-panel,.sidebar,.shared-scrollbar-panel,.dialog-backdrop,.empty-pane,.workspace{display:none!important}.print-workspace{display:block}.panel{border:1px solid #bdbdbd;border-radius:0;box-shadow:none;background:#fff;padding:.45rem;margin-bottom:.55rem;break-inside:avoid-page;page-break-inside:avoid}.canvas-panel,.report-panel,.print-panel{height:auto!important;overflow:visible!important;min-height:0;break-before:auto;page-break-before:auto}.print-report-panel{break-before:auto;page-break-before:auto;break-after:auto;page-break-after:auto}.panel-title{margin-bottom:.35rem;break-after:avoid-page;page-break-after:avoid}.canvas-scroll{height:auto!important;max-height:none!important;min-height:0;overflow:visible!important;border:none;border-radius:0;background:transparent;padding:0;display:block;break-before:avoid-page;page-break-before:avoid}.print-panel .canvas-scroll{display:flex;justify-content:center;align-items:flex-start}.canvas-scroll>.bead-canvas,.canvas-scroll>.bead-preview-canvas{margin:0 auto;max-width:100%;height:auto}.report-content{overflow:visible;max-height:none;padding-right:0}}
