:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#e8e0d5;background:#1a1a1a;height:100dvh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;overflow:hidden}.app{grid-template-rows:44px 1fr;grid-template-columns:1fr 240px;height:100dvh;display:grid}.toolbar{background:#252525;border-bottom:1px solid #333;grid-column:1/-1;align-items:center;gap:10px;padding:0 14px;display:flex}.app-title{color:#c8b89a;flex:none;margin-right:4px;font-size:15px;font-weight:600}.toolbar-group{gap:4px;display:flex}button,.file-btn{color:#e8e0d5;cursor:pointer;white-space:nowrap;background:#3a3a3a;border:1px solid #555;border-radius:6px;padding:4px 10px;font-size:12px;transition:background .15s}button:hover,.file-btn:hover{background:#484848}button.active{color:#e8d5b0;background:#5a4030;border-color:#a07050}.canvas-area{background:#1a1a1a;position:relative;overflow:hidden}.bowl-canvas{width:100%;height:100%;display:block}.bowl-canvas.hidden{display:none}.cutlist-area{padding:24px;position:absolute;inset:0;overflow:auto}.sidebar{background:#222;border-left:1px solid #333;flex-direction:column;display:flex;overflow:hidden}.sidebar-header{flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 12px 6px;display:flex}.sidebar-header h3{color:#c8b89a;font-size:13px;font-weight:600}.add-ring-btn{color:#e8e0d5;cursor:pointer;background:#3a3a3a;border:1px solid #555;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;padding:0;font-size:18px;line-height:1;display:flex}.add-ring-btn:hover{background:#5a4030;border-color:#a07050}.ring-list{flex-direction:column;flex:1;gap:4px;padding:0 8px 8px;display:flex;overflow-y:auto}.ring-row{border:1px solid #333;border-radius:6px;transition:border-color .1s;overflow:hidden}.ring-row.selected{border-color:#a07050}.ring-row-header{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:6px 8px;display:flex}.ring-row-header:hover{background:#2a2a2a}.ring-row.selected .ring-row-header{background:#3a2810}.ring-label{color:#c8b89a;font-size:12px;font-weight:600;display:block}.ring-detail{color:#888;margin-top:1px;font-size:10px;display:block}.remove-btn{color:#666;cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0 2px;font-size:16px;line-height:1}.remove-btn:hover{color:#c54;background:0 0}.ring-editor{background:#1e1e1e;border-top:1px solid #333;flex-direction:column;gap:6px;padding:8px 10px 10px;display:flex}.field{align-items:center;gap:6px;display:flex}.field label{color:#888;flex:0 0 80px;font-size:11px}.field input[type=number],.field select{color:#e8e0d5;background:#2a2a2a;border:1px solid #444;border-radius:4px;flex:1;min-width:0;padding:3px 6px;font-size:12px}.field input[type=number]:focus,.field select:focus{border-color:#a07050;outline:none}.sidebar-tabs{border-bottom:1px solid #333;flex-shrink:0;display:flex}.tab-btn{color:#888;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;border-radius:0;flex:1;padding:8px 4px;font-size:12px;font-weight:500;transition:color .15s}.tab-btn:hover{color:#c8b89a;background:0 0}.tab-btn.active{color:#c8b89a;background:0 0;border-bottom-color:#a07050}.global-species{border-top:1px solid #333;flex-shrink:0;padding:10px 12px}.global-species label{color:#888;flex-direction:column;gap:4px;font-size:11px;display:flex}.global-species select{color:#e8e0d5;background:#2a2a2a;border:1px solid #444;border-radius:4px;padding:3px 6px;font-size:12px}.settings-panel{flex:1;padding:0 0 8px;overflow-y:auto}.settings-section{border-bottom:1px solid #2a2a2a;padding:8px 12px 6px}.settings-section-title{color:#888;text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;font-size:10px;font-weight:700}.settings-row{align-items:center;gap:6px;margin-bottom:4px;display:flex}.info-row{margin-top:2px}.settings-label{color:#888;flex:0 0 100px;font-size:11px}.settings-value{font-size:11px;font-weight:600}.settings-select{color:#e8e0d5;background:#2a2a2a;border:1px solid #444;border-radius:4px;flex:1;min-width:0;padding:3px 6px;font-size:12px}.settings-select:focus{border-color:#a07050;outline:none}.settings-btn{width:100%;margin-top:4px;padding:4px 8px;font-size:11px}.settings-note{color:#666;font-size:11px}.ring-row-reorder{flex-direction:column;flex-shrink:0;gap:1px;margin-right:4px;display:flex}.reorder-btn{color:#555;cursor:pointer;background:0 0;border:none;padding:1px 2px;font-size:8px;line-height:1}.reorder-btn:hover{color:#c8b89a;background:0 0}.ring-chevron{color:#666;flex-shrink:0;margin:0 4px;font-size:10px}.template-overlay{z-index:100;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.template-picker{background:#252525;border:1px solid #444;border-radius:12px;width:480px;max-width:90vw;max-height:80vh;padding:20px;overflow-y:auto}.template-picker-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.template-picker h3{color:#c8b89a;margin-bottom:0;font-size:15px;font-weight:600}.template-cancel{color:#888;cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:12px}.template-cancel:hover{color:#e8e0d5;background:0 0}.template-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.template-card{text-align:left;cursor:pointer;background:#2a2a2a;border:1px solid #444;border-radius:8px;flex-direction:column;gap:4px;padding:12px;transition:border-color .15s,background .15s;display:flex}.template-card:hover{background:#3a3a3a;border-color:#a07050}.template-name{color:#c8b89a;font-size:13px;font-weight:600}.template-desc{color:#888;font-size:11px;line-height:1.4}.cl-section{margin-bottom:24px}.cl-section-title{color:#c8b89a;text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;font-size:12px;font-weight:700}.cl-params{grid-template-columns:1fr 1fr;gap:4px 16px;margin-bottom:8px;display:grid}.cl-param-row{gap:8px;font-size:12px;display:flex}.cl-param-label{color:#888}.cl-param-value{color:#e8e0d5;font-weight:500}.cut-list table{border-collapse:collapse;width:100%;font-size:13px}.cut-list th,.cut-list td{text-align:right;white-space:nowrap;border-bottom:1px solid #333;padding:8px 12px}.cut-list th{color:#c8b89a;text-transform:uppercase;letter-spacing:.04em;background:#252525;font-size:11px;font-weight:600;position:sticky;top:0}.cut-list th:first-child,.cut-list td:first-child{text-align:left}.cut-list tr:hover td{background:#2a2a2a}.cut-list-empty{color:#888;text-align:center;padding:24px 0;font-size:13px}.sse-root{border-top:1px solid #2a2a2a;flex-direction:column;gap:6px;margin-top:2px;padding-top:4px;display:flex}.sse-canvas{aspect-ratio:1;cursor:pointer;background:#1a1a1a;border-radius:6px;width:100%;display:block}.sse-sel-bar{background:#1e2e1e;border:1px solid #3a5a3a;border-radius:6px;flex-wrap:wrap;align-items:center;gap:4px;padding:5px 7px;display:flex}.sse-sel-label{color:#8dc87a;flex-shrink:0;font-size:11px}.sse-sel-clear,.sse-sel-reset{color:#888;cursor:pointer;background:#2a2a2a;border:1px solid #444;border-radius:4px;padding:2px 6px;font-size:10px}.sse-sel-clear:hover,.sse-sel-reset:hover{color:#e8e0d5}.sse-sel-reset{color:#c88;border-color:#804040}.sse-sel-reset:hover{background:#3a1a1a}.sse-sel-swatches{flex-wrap:wrap;gap:2px;display:flex}.sse-mini-swatch{cursor:pointer;border:1px solid #0000004d;border-radius:2px;flex-shrink:0;width:14px;height:14px;padding:0}.sse-mini-swatch.active{outline:2px solid #a07050}.sse-mini-swatch:hover{transform:scale(1.2)}.sse-species-select{color:#e8e0d5;background:#2a2a2a;border:1px solid #444;border-radius:4px;max-width:90px;padding:1px 4px;font-size:10px}.sse-patterns{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.sse-patterns-label{color:#666;flex-shrink:0;min-width:36px;font-size:10px}.sse-pat-btn{color:#c8b89a;cursor:pointer;background:#2a2a2a;border:1px solid #444;border-radius:4px;padding:2px 7px;font-size:10px}.sse-pat-btn:hover{background:#3a3a3a}.sse-pat-btn:disabled{color:#444;cursor:default}.sse-pat-btn-danger{color:#c88;border-color:#804040}.sse-pat-btn-danger:hover{background:#3a1a1a}.sse-paint-row{align-items:center;gap:6px;display:flex}.sse-paint-swatches{flex-wrap:wrap;align-items:center;gap:2px;display:flex}.ring-pattern-btn{color:#8dc87a;background:#2a3a28;border-color:#4a7040;width:100%;margin-top:2px;padding:5px 8px;font-size:11px}.ring-pattern-btn:hover{background:#364a32;border-color:#6a9a60}.pbe-overlay{z-index:200;background:#000000b8;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.pbe-modal{background:#252525;border:1px solid #444;border-radius:12px;flex-direction:column;width:560px;max-width:100%;max-height:90vh;display:flex;overflow:hidden}.pbe-header{border-bottom:1px solid #333;flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.pbe-title{color:#c8b89a;font-size:14px;font-weight:600}.pbe-header-actions{gap:6px;display:flex}.pbe-body{flex-direction:column;flex:1;gap:14px;padding:14px 16px 18px;display:flex;overflow-y:auto}.pbe-btn-primary{color:#e8d5b0;cursor:pointer;background:#5a4030;border:1px solid #a07050;border-radius:6px;padding:5px 12px;font-size:12px}.pbe-btn-primary:hover{background:#6a5040}.pbe-btn-secondary{color:#e8e0d5;cursor:pointer;background:#3a3a3a;border:1px solid #555;border-radius:6px;padding:5px 10px;font-size:12px}.pbe-btn-secondary:hover{background:#484848}.pbe-btn-danger{color:#c88;cursor:pointer;background:#3a1a1a;border:1px solid #804040;border-radius:6px;padding:5px 10px;font-size:12px}.pbe-btn-danger:hover{background:#4a2222}.pbe-btn-danger:disabled{opacity:.4;cursor:default}.pbe-btn-sm{padding:3px 8px;font-size:11px}.pbe-section{flex-direction:column;gap:6px;display:flex}.pbe-section-title{color:#888;text-transform:uppercase;letter-spacing:.06em;font-size:10px;font-weight:700}.pbe-dims{align-items:center;gap:12px;display:flex}.pbe-dim-group{flex:1;align-items:center;gap:6px;display:flex}.pbe-dim-label{color:#c8b89a;flex:0 0 50px;font-size:12px}.pbe-dim-note{color:#666;font-size:10px}.pbe-dim-divider{background:#333;flex-shrink:0;width:1px;height:24px}.pbe-stepper{align-items:center;gap:4px;display:flex}.pbe-stepper button{color:#e8e0d5;cursor:pointer;background:#3a3a3a;border:1px solid #555;border-radius:4px;justify-content:center;align-items:center;width:22px;height:22px;padding:0;font-size:14px;line-height:1;display:flex}.pbe-stepper button:hover{background:#484848}.pbe-stepper span{color:#e8e0d5;text-align:center;min-width:24px;font-size:13px;font-weight:600}.pbe-preset-bar{justify-content:space-between;align-items:center;display:flex}.pbe-preset-label{color:#888;font-size:11px}.pbe-presets{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.pbe-preset-card{cursor:pointer;background:#2a2a2a;border:1px solid #444;border-radius:6px;flex-direction:column;align-items:center;gap:4px;padding:8px 6px 6px;transition:border-color .12s,background .12s;display:flex}.pbe-preset-card:hover{background:#333;border-color:#a07050}.pbe-preset-thumb{border-radius:3px;width:60px;height:40px;display:block}.pbe-preset-name{color:#c8b89a;text-align:center;font-size:11px}.pbe-preset-size{color:#666;font-size:10px}.pbe-grid-wrap{background:#1a1a1a;border:1px solid #444;border-radius:6px;overflow:hidden}.pbe-grid-canvas{cursor:crosshair;width:100%;display:block}.pbe-tool-toggle{gap:4px;display:flex}.pbe-tool-toggle button{color:#888;cursor:pointer;background:#3a3a3a;border:1px solid #555;border-radius:6px;padding:5px 12px;font-size:12px}.pbe-tool-toggle button:hover{color:#e8e0d5;background:#484848}.pbe-tool-toggle button.active{color:#e8d5b0;background:#5a4030;border-color:#a07050}.pbe-palette{flex-wrap:wrap;gap:3px;display:flex}.pbe-swatch{cursor:pointer;border:none;border-radius:3px;flex-shrink:0;width:18px;height:18px;padding:0}.pbe-active-species{color:#c8b89a;align-items:center;gap:6px;margin-top:4px;font-size:12px;display:flex}.pbe-swatch-lg{border:1px solid #ffffff26;border-radius:4px;flex-shrink:0;width:20px;height:20px;display:inline-block}.pbe-strip-note{color:#666;margin-bottom:4px;font-size:11px}.pbe-strips{flex-direction:column;gap:8px;display:flex}.pbe-strip-row{background:#1e1e1e;border:1px solid #333;border-radius:6px;flex-direction:column;gap:4px;padding:8px 10px;display:flex}.pbe-strip-header{justify-content:space-between;align-items:center;display:flex}.pbe-strip-label{color:#c8b89a;font-size:12px;font-weight:600}.pbe-strip-meta{color:#666;font-size:11px}.pbe-strip-swatches{gap:2px;display:flex}.pbe-strip-swatch{border:1px solid #0003;border-radius:2px;flex-shrink:0;width:14px;height:14px}.pbe-strip-species-names{color:#888;font-size:10px}.context-menu-overlay{z-index:1000;position:fixed;inset:0}.context-menu{z-index:1001;background:#2a2a2a;border:1px solid #444;border-radius:6px;min-width:170px;margin:0;padding:4px 0;list-style:none;position:fixed;box-shadow:0 4px 16px #00000080}.context-menu li{color:#ddd;cursor:pointer;-webkit-user-select:none;user-select:none;padding:7px 14px;font-size:13px}.context-menu li:hover{color:#fff;background:#3a2810}.context-menu li.disabled{color:#555;cursor:default}.context-menu li.disabled:hover{color:#555;background:0 0}.expert-mode-bar{color:#fff;background:#c82828d9;flex-shrink:0;align-items:center;gap:8px;padding:7px 16px;font-size:12px;font-weight:600;display:flex}.constraint-badge{cursor:default;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:11px;font-weight:700;display:inline-flex}.constraint-badge.critical{color:#fff;background:#c55}.constraint-badge.warn{color:#fff;background:#c87020}.sort-toggle-btn{color:#aaa;cursor:pointer;background:0 0;border:1px solid #444;border-radius:4px;flex-shrink:0;padding:2px 6px;font-size:10px}.sort-toggle-btn:hover{color:#ccc;background:#2a2a2a}.species-turning-note{border-radius:4px;align-items:flex-start;gap:5px;padding:6px 8px;font-size:11px;line-height:1.4;display:flex}.species-turning-note.caution{color:#c87020;background:#c8821e26;border-left:2px solid #c87020}.species-turning-note.avoid{color:#c55;background:#c83c3c26;border-left:2px solid #c55}.species-turning-icon{flex-shrink:0}.species-alternatives{color:#aaa;margin-top:3px;display:block}.expert-mode-label{color:#ddd;cursor:pointer;align-items:center;gap:8px;font-size:13px;display:flex}.expert-confirm{color:#ddd;background:#2a1a1a;border:1px solid #c55;border-radius:6px;margin-top:6px;padding:10px 12px;font-size:12px;line-height:1.5}.expert-confirm p{margin:0 0 6px}.expert-confirm p:last-of-type{margin-bottom:10px}.expert-confirm-btns{gap:8px;display:flex}.expert-confirm-ok{color:#fff;cursor:pointer;background:#c55;border:none;border-radius:4px;padding:5px 12px;font-size:12px}.expert-confirm-ok:hover{background:#d44}.calc-specs{background:#c0a06414;border:1px solid #c0a0642e;border-radius:6px;flex-direction:column;gap:3px;margin-top:4px;padding:7px 10px;display:flex}.calc-spec-row{justify-content:space-between;font-size:11px;display:flex}.calc-spec-row span:first-child{color:#888}.calc-spec-row span:last-child{color:#e8d5b0;font-family:monospace}.rotation-stepper{flex:1;align-items:center;gap:4px;display:flex}.rotation-stepper button{color:#e8e0d5;cursor:pointer;background:#3a3a3a;border:1px solid #555;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;padding:0;font-size:14px;line-height:1;display:flex}.rotation-stepper button:hover{background:#484848}.rotation-label{color:#c8b89a;text-align:center;flex:1;font-family:monospace;font-size:11px}.goalseek-panel{margin:2px 0 4px}.settings-btn-inline{color:#e8e0d5;cursor:pointer;white-space:nowrap;background:#3a3a3a;border:1px solid #555;border-radius:4px;flex-shrink:0;padding:3px 9px;font-size:11px}.settings-btn-inline:hover{background:#484848}.cl-paywall-banner{background:#1e1510;border:1px solid #7a5c28;border-radius:8px;align-items:center;gap:16px;margin-bottom:16px;padding:14px 16px;display:flex}.cl-paywall-main{color:#ddd;flex:1;font-size:13px;line-height:1.5}.cl-paywall-main strong{color:#e8c870;margin-bottom:4px;font-size:14px;display:block}.cl-paywall-main p{color:#aaa;margin:0;font-size:12px}.cl-paywall-btn{color:#111;cursor:pointer;white-space:nowrap;background:#c8a020;border:none;border-radius:6px;flex-shrink:0;padding:8px 16px;font-size:13px;font-weight:700}.cl-paywall-btn:hover{background:#e0b828}.cl-locked{color:#7a5c28;white-space:nowrap;font-size:11px}.cl-row-locked td{opacity:.75}.template-lock-badge{color:#111;vertical-align:middle;text-transform:uppercase;letter-spacing:.03em;background:#c8a020;border-radius:3px;margin-left:6px;padding:1px 5px;font-size:9px;font-weight:700;display:inline-block}.template-card-locked{opacity:.7;border-style:dashed!important}.template-card-locked:hover{opacity:.9}.ring-species-swatch{border-radius:2px 0 0 2px;flex-shrink:0;align-self:stretch;width:6px;margin-right:4px}.overlap-ok-badge{color:#6a6;cursor:default;flex-shrink:0;margin-right:2px;font-size:12px;font-weight:700}.cl-toolbar{justify-content:flex-end;margin-bottom:8px;display:flex}.cl-print-btn{color:#c8b89a;cursor:pointer;background:#2a2a2a;border:1px solid #444;border-radius:5px;padding:5px 12px;font-size:13px}.cl-print-btn:hover{background:#3a3a3a}.cl-species-swatch{vertical-align:middle;border-radius:2px;flex-shrink:0;width:12px;height:12px;margin-right:5px;display:inline-block}.cl-species-swatch-lg{vertical-align:middle;border-radius:3px;flex-shrink:0;width:18px;height:14px;margin-right:6px;display:inline-block}.cl-ring-detail{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:6px;margin-bottom:8px;padding:10px 12px}.cl-ring-detail-header{color:#c8b89a;align-items:center;margin-bottom:6px;font-size:13px;font-weight:600;display:flex}.cl-species-notes{flex-direction:column;gap:6px;margin-top:8px;display:flex}.cl-species-note{border-left:3px solid;border-radius:4px;padding:6px 8px;font-size:12px;line-height:1.4}.cl-species-note.caution{color:#c8a060;background:#c88c1e1f;border-color:#c87020}.cl-species-note.avoid{color:#e08080;background:#c83c3c1f;border-color:#c55}.cl-species-note-badge{margin-right:4px;font-weight:700}.cl-species-note-name{margin-right:4px;font-weight:600}.cl-species-alternatives{color:#888;margin-top:3px;padding-left:12px;font-size:11px}@media print{body{color:#000;background:#fff}.cl-toolbar,.cl-paywall-banner,.cl-paywall-btn{display:none}.cut-list{color:#000;background:#fff}.cl-section-title{color:#333;border-color:#ccc}.cl-param-label{color:#555}.cl-param-value{color:#111}.cl-locked{color:#999}}
