﻿:root{--bg:#faf9f7;--bg-card:#ffffff;--bg-dark:#1a1a1a;--text:#1a1a1a;--text-muted:#6b6b6b;--text-light:#faf9f7;--accent:#2c2c2c;--accent-hover:#444;--border:#e0ddd8;--border-dark:#1a1a1a;--shadow:0 2px 12px rgba(0,0,0,0.06);--shadow-hover:0 6px 24px rgba(0,0,0,0.10);--radius:2px;--font:'Segoe UI',system-ui,-apple-system,sans-serif;--font-heading:Georgia,'Times New Roman',serif;--transition:0.2s ease}html{scrollbar-gutter:stable}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh;display:flex;flex-direction:column}body.mobile-menu-open{overflow:hidden}header{background:var(--bg);border-bottom:2px solid var(--border-dark);position:sticky;top:0;z-index:100}.header-top{max-width:1200px;margin:0 auto;padding:16px 24px 12px;display:flex;align-items:center;justify-content:space-between;gap:20px}.logo{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-heading);font-size:1.35rem;letter-spacing:0.8px;cursor:pointer;white-space:nowrap;text-decoration:none;color:var(--text)}.logo-mark{width:34px;height:34px;display:block;background-image:url("/projectknit_logo.svg");background-size:contain;background-position:center;background-repeat:no-repeat}.logo span{font-weight:500;line-height:1}.search-container{flex:1;max-width:400px;position:relative}.search-container input{width:100%;padding:10px 16px 10px 40px;border:1.5px solid var(--border);background:var(--bg);font-size:0.9rem;font-family:var(--font);transition:var(--transition);outline:none}.search-container input:focus{border-color:var(--border-dark)}.search-container i{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:0.85rem}.header-controls{display:flex;align-items:center;gap:8px}.header-controls .btn:not(.btn-icon){height:38px;display:inline-flex;align-items:center;justify-content:center;padding:0 20px}.header-preferences-btn{display:inline-flex;align-items:center;gap:8px;min-width:88px}.header-preferences-btn i{font-size:0.9rem}.btn{padding:8px 18px;border:1.5px solid var(--border-dark);background:transparent;color:var(--text);font-family:var(--font);font-size:0.82rem;letter-spacing:1px;text-transform:uppercase;cursor:pointer;transition:var(--transition);white-space:nowrap}button.async-btn{display:inline-flex;align-items:center;justify-content:center;gap:0.4em}button.async-btn .async-btn-prefix{width:0;height:1em;flex:0 0 0;display:inline-flex;align-items:center;justify-content:center;opacity:0;overflow:hidden;transition:width 0.15s ease-in-out,opacity 0.15s ease-in-out}button.async-btn .async-btn-spinner{width:0.9em;height:0.9em;border-radius:999px;border:0.12em solid currentColor;border-right-color:transparent;opacity:0;transition:opacity 0.15s ease-in-out;animation:async-btn-spin 0.75s linear infinite}button.async-btn.async-btn-loading .async-btn-spinner{opacity:1}button.async-btn.async-btn-loading .async-btn-prefix{width:1em;opacity:1}@keyframes async-btn-spin{to{transform:rotate(360deg)}}.btn:hover{background:var(--bg-dark);color:var(--text-light)}.btn.active{background:var(--bg-dark);color:var(--text-light)}.btn:disabled{opacity:0.38;cursor:default;pointer-events:none}.btn-filled{background:var(--bg-dark);color:var(--text-light)}.btn-filled:hover{background:var(--accent-hover)}.btn-small{padding:6px 12px;font-size:0.75rem}.btn-loading-state{display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn-loading-spinner{width:0.95em;height:0.95em;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:btn-loading-spin 0.7s linear infinite;flex:0 0 auto}@keyframes btn-loading-spin{to{transform:rotate(360deg)}}.btn-icon{width:38px;height:38px;padding:0;display:flex;align-items:center;justify-content:center;font-size:1rem}.hamburger{display:none;background:none;border:none;font-size:1.4rem;cursor:pointer;padding:8px;color:var(--text)}nav{max-width:1200px;margin:0 auto;padding:0 24px 12px;display:flex;gap:24px}nav a{text-decoration:none;color:var(--text-muted);font-size:0.82rem;letter-spacing:1.5px;text-transform:uppercase;padding:4px 0;border-bottom:1.5px solid transparent;transition:var(--transition);cursor:pointer}nav a:hover,nav a.active{color:var(--text);border-bottom-color:var(--text)}main{max-width:1200px;margin:0 auto;padding:32px 24px 60px;width:100%;flex:1;position:relative}main.page-transition-loading::after{content:attr(data-loading-label);position:sticky;top:18px;display:inline-flex;margin-left:auto;padding:8px 12px;border:1px solid var(--border);background:rgba(255,255,255,0.96);color:var(--text-muted);font-size:0.74rem;letter-spacing:1px;text-transform:uppercase;box-shadow:var(--shadow);z-index:5}.async-page-shell{min-height:clamp(360px,58vh,720px);display:flex;align-items:center;justify-content:center;padding:32px 24px;border:1.5px solid var(--border);background:linear-gradient(180deg,#fbf8f4 0%,#f4efe7 100%)}.async-page-shell-tools{min-height:clamp(420px,64vh,820px)}.async-page-shell-status{padding:12px 16px;border:1px solid var(--border);background:rgba(255,255,255,0.9);color:var(--text-muted);font-size:0.82rem;letter-spacing:1px;text-transform:uppercase}.async-page-shell-error .async-page-shell-status{color:var(--text)}.catalog-header{margin-bottom:32px}.catalog-header h1{font-family:var(--font-heading);font-size:1.8rem;font-weight:400;margin-bottom:4px}.catalog-header p{color:var(--text-muted);font-size:0.9rem}.pricing-panels{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;align-items:stretch}.pricing-card{border:1.5px solid var(--border);background:var(--bg-card);padding:20px;display:flex;flex-direction:column;gap:12px;transition:var(--transition)}.pricing-card:hover{border-color:var(--border-dark);box-shadow:var(--shadow-hover)}.pricing-card-featured{border-color:var(--border-dark)}.pricing-card.selected{border-color:var(--border-dark);box-shadow:var(--shadow-hover)}.pricing-card.selected:hover{transform:translateY(-2px)}.pricing-card-tag{align-self:flex-start;font-size:0.7rem;letter-spacing:1.4px;text-transform:uppercase;border:1px solid var(--border);padding:4px 8px;color:var(--text-muted);background:#f7f4ef}.pricing-card h2{font-family:var(--font-heading);font-weight:400;font-size:1.5rem;margin:0}.pricing-card h3{font-family:var(--font-heading);font-size:1.05rem;font-weight:400;margin:0}.pricing-card-price{font-size:0.92rem;letter-spacing:1px;text-transform:uppercase;color:var(--text);font-weight:600}.pricing-card-divider{height:1px;background:var(--border);margin:2px 0}.pricing-card ul{margin:0;padding-left:18px;color:var(--text-muted);display:flex;flex-direction:column;gap:7px}.pricing-card-top-list li{color:var(--text)}.pricing-card-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:auto;padding-top:8px}.pricing-card-actions .btn{width:100%}.legal-page{max-width:900px;margin:0 auto}.legal-page .catalog-header{margin-bottom:20px}.legal-sections{display:flex;flex-direction:column;gap:14px}.legal-section{gap:10px}.legal-section h2{font-family:var(--font-heading);font-weight:400;font-size:1.2rem;margin:0}.legal-section p{margin:0;color:var(--text-muted);line-height:1.65}.legal-section p.legal-strong{color:var(--text)}.legal-highlight{border:1.5px solid var(--border-dark);background:#f7f4ef}.legal-meta{font-size:0.78rem;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted)}@media (max-width:768px){.pricing-panels{grid-template-columns:1fr}.pricing-card{padding:16px}}.pattern-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}.pattern-card{border:1.5px solid var(--border);background:var(--bg-card);cursor:pointer;transition:var(--transition);position:relative;overflow:hidden}.pattern-card:hover{border-color:var(--border-dark);box-shadow:var(--shadow-hover)}.pattern-card-img{width:100%;height:260px;background:#e8e5e0;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.pattern-card-img svg{width:100%;height:100%}.pattern-card-img-blog{background:#ece8e1}.pattern-card-img-blog .pattern-card-blog-image{width:100%;height:100%;display:block;object-fit:contain;object-position:center center;background:#ece8e1}.pattern-card-img-tool{background:#f2ede6}.pattern-card-img-tool i{font-size:2rem;color:#4f473c}.tools-selector{margin-bottom:12px}.tools-selector-head{display:flex;align-items:center;justify-content:flex-end;gap:6px;margin-bottom:8px}.tool-nav-btn{width:32px;height:32px;border:1.5px solid var(--border-dark);background:var(--bg-card);color:var(--text);cursor:pointer}.tool-nav-btn:hover{background:var(--bg-dark);color:var(--text-light)}.tools-carousel{display:flex;gap:8px;overflow-x:auto;padding-bottom:8px;scroll-snap-type:x mandatory;scrollbar-width:thin;scroll-padding-inline:1px;overscroll-behavior-x:contain;-webkit-overflow-scrolling:touch}.tool-card{flex:0 0 180px;min-height:84px;border:1.5px solid var(--border);background:var(--bg-card);color:var(--text);display:flex;align-items:center;gap:10px;padding:10px;text-align:left;cursor:pointer;scroll-snap-align:start}.tool-card-icon{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);background:#f2ede6;color:#4f473c;flex:0 0 auto}.tool-card-label{font-family:var(--font-heading);font-size:0.88rem;line-height:1.2;overflow-wrap:anywhere}.tool-card.active,.tool-card:focus-visible{border-color:var(--border-dark);box-shadow:var(--shadow);outline:none}.tools-selected-summary{border:1px solid var(--border);background:#f7f3ec;padding:10px 12px;margin-bottom:12px}.tools-selected-summary p{margin:0;color:var(--text-muted);font-size:0.88rem}.tool-workspace{margin-top:0;border:1.5px solid var(--border);background:var(--bg-card);padding:20px}.tool-workspace.loading{opacity:0.7}.tool-panel h2{font-family:var(--font-heading);font-weight:400;font-size:1.25rem;margin-bottom:6px}.tool-panel p{color:var(--text-muted);margin-bottom:14px}.tool-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:10px}.tool-form-row{display:flex;gap:10px;flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px}.tool-form-row .tool-field{flex:1 1 0;min-width:170px}.tool-field{display:flex;flex-direction:column;gap:6px}.tool-field span{font-size:0.7rem;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted)}.tool-field input,.tool-field select{width:100%;padding:9px 10px;border:1.5px solid var(--border);background:var(--bg);font-family:var(--font);font-size:0.84rem;outline:none}.tool-field input:focus,.tool-field select:focus{border-color:var(--border-dark)}.tool-result{margin-top:12px;padding:9px 10px;border:1px solid var(--border);background:#f7f3ec;color:var(--text);font-size:0.84rem;overflow-wrap:anywhere}.tool-visual{margin-top:10px;border:1px dashed var(--border);background:#fbf8f3;padding:10px;display:flex;flex-wrap:wrap;gap:8px}.tool-visual-item{border:1px solid var(--border);background:var(--bg-card);padding:6px 8px;font-size:0.76rem;color:var(--text-muted)}.tool-visual-item strong{color:var(--text);font-family:var(--font-heading);font-size:0.9rem}.tool-meter{width:100%}.tool-meter span{display:block;margin-bottom:4px;font-size:0.72rem;color:var(--text-muted)}.tool-meter-track{height:8px;border:1px solid var(--border);background:#efe9e1}.tool-meter-fill{display:block;height:100%;background:#5f5343}.pattern-card-body{padding:16px 18px 18px}.pattern-card-body h3{font-family:var(--font-heading);font-size:1.05rem;font-weight:400;margin-bottom:6px;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.pattern-card-body p{color:var(--text-muted);font-size:0.82rem;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.pattern-card-tags{padding:0 18px 14px;display:flex;gap:6px;flex-wrap:wrap}.pattern-card-tags-catalog{padding-bottom:8px;max-height:calc((22px * 2) + 6px + 8px);overflow:hidden;align-content:flex-start}.pattern-grid-blog-catalog{align-items:start}@media (min-width:561px){.pattern-grid-blog-catalog{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}}.tag{display:inline-flex;align-items:center;font-size:0.7rem;line-height:1.1;letter-spacing:1px;text-transform:uppercase;padding:3px 8px;min-height:22px;border:1px solid var(--border);color:var(--text-muted)}.blog-search-results-header{margin-top:20px}.pattern-card-creator{font-size:0.72rem;color:var(--text-muted);margin-top:6px;font-style:italic}.detail-view{display:block;--blog-media-max-width:900px}.detail-back{margin-bottom:8px}.detail-back a{color:var(--text-muted);text-decoration:none;font-size:0.82rem;letter-spacing:1px;text-transform:uppercase;cursor:pointer;transition:var(--transition)}.detail-back a:hover{color:var(--text)}.detail-title-centered{font-family:var(--font-heading);font-size:1.8rem;font-weight:400;text-align:center;margin-bottom:24px}.blog-meta{display:flex;justify-content:center;margin-bottom:12px;color:var(--text-muted);font-size:0.8rem;letter-spacing:0.9px;text-transform:uppercase}.blog-section-shell{border:1.5px solid var(--border);padding:14px 16px 10px;background:#f8f5f1;margin-bottom:18px;max-width:var(--blog-media-max-width);margin-left:auto;margin-right:auto}.blog-section-shell h3{font-family:var(--font-heading);font-weight:400;font-size:1rem;margin-bottom:8px}.blog-tags{display:flex;gap:6px;flex-wrap:wrap}.blog-tags .tag{background:var(--bg-card)}.blog-content{border:1.5px solid var(--border);background:var(--bg-card);padding:18px;color:var(--text);max-width:var(--blog-media-max-width);margin:0 auto}.blog-content h1,.blog-content h2{font-family:var(--font-heading);font-weight:400;margin:0 0 10px}.blog-content p{margin-bottom:12px}.blog-content ul{margin:0 0 12px 18px}.blog-content img{max-width:min(100%,var(--blog-media-max-width));height:auto}.blog-content video{display:block;max-width:min(100%,var(--blog-media-max-width));height:auto}.blog-content .blog-editor-row{display:flex;flex-wrap:wrap;gap:14px;margin:0 0 16px}.blog-content .blog-editor-row-column{flex:1 1 calc(var(--blog-col-width,100%) - 14px);min-width:min(100%,220px);max-width:100%}.blog-content .blog-editor-row-column>:last-child{margin-bottom:0}@media (max-width:720px){.blog-content .blog-editor-row{flex-direction:column}.blog-content .blog-editor-row-column{flex-basis:100%;width:100%}}.detail-main{display:block}.detail-left{min-width:0;display:flex;flex-direction:column;gap:14px}.detail-svg-container{position:relative;width:100%;max-width:100%;min-height:clamp(420px,72vw,980px);padding:46px 14px 14px 56px;border:1.5px solid var(--border);background:#f5f3ef;overflow:auto;text-align:center}.detail-svg-container svg{display:block;width:min(100%,1000px);max-width:100%;height:auto;flex:none;margin-left:auto;margin-right:auto}.detail-reset-polygons{position:absolute;top:5px;left:5px;z-index:2;padding:6px 10px;border:1px solid #c9c3bb;background:#ffffff;color:#2f2c28;font-size:0.75rem;letter-spacing:0.5px;text-transform:uppercase;cursor:pointer}.detail-svg-mobile-controls{display:flex;gap:8px;justify-content:flex-start;align-items:center;flex-wrap:wrap;margin-top:8px}.detail-svg-mobile-toggle{padding:6px 10px;border:1px solid #c9c3bb;background:#ffffff;color:#2f2c28;font-size:0.75rem;letter-spacing:0.5px;text-transform:uppercase;cursor:pointer}#detail-project-svg{display:block;width:min(100%,1000px);max-width:100%;height:auto}.detail-project-dimension{position:absolute;z-index:2;padding:6px 11px;border:1.5px solid var(--border);background:rgba(255,255,255,0.92);color:var(--text-muted);font-size:0.82rem;line-height:1.2;letter-spacing:0.6px;pointer-events:none;white-space:nowrap}.detail-project-dimension-svg{display:block;width:220px;height:14px}.detail-project-dimension-svg-vertical{width:14px;height:220px}.detail-project-dimension-line{fill:none;stroke:currentColor;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}.detail-project-dimension-text{fill:currentColor;font-size:10px;letter-spacing:0.3px}.detail-project-dimension-top{top:5px;left:50%;transform:translateX(-50%)}.detail-project-dimension-left{left:5px;top:50%;transform:translateY(-50%);transform-origin:center;width:30px;height:232px;padding:4px;display:flex;align-items:center;justify-content:center}.detail-project-dimension-left .detail-project-dimension-svg{width:14px;height:220px}.detail-svg-live-stats{position:absolute;bottom:5px;left:5px;z-index:2;min-width:170px;padding:7px 9px;border:1px solid var(--border);background:rgba(255,255,255,0.92);color:var(--text);font-size:0.74rem;line-height:1.35;pointer-events:none}.detail-svg-live-stats-row{display:inline-flex;gap:10px;flex-wrap:wrap;align-items:center}.detail-svg-live-title{font-weight:600;margin-bottom:4px;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.5px}.detail-left .description{color:var(--text-muted);font-size:0.92rem;margin:20px 0 0;line-height:1.7;white-space:break-spaces}.detail-variant-switch{margin:0 0 8px;width:min(230px,100%)}.detail-svg-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding:24px;color:#6b6b6b;font-size:0.9rem;letter-spacing:0.6px;background:linear-gradient(180deg,rgba(245,243,239,0.96) 0%,rgba(245,243,239,0.88) 100%);transition:opacity 160ms ease;pointer-events:none;z-index:1}.detail-svg-container[data-detail-svg-state="loading"] #detail-project-svg,.detail-svg-container[data-detail-svg-state="loading"] .detail-project-dimension,.detail-svg-container[data-detail-svg-state="loading"] .detail-svg-live-stats,.detail-svg-container[data-detail-svg-state="loading"] .detail-reset-polygons{opacity:0}.detail-svg-container[data-detail-svg-state="ready"] .detail-svg-loading,.detail-svg-container[data-detail-svg-state="error"] .detail-svg-loading{opacity:0}.detail-polygon-card{height:100%;display:flex;flex-direction:column;gap:10px}.detail-polygon-meta{display:flex;flex-direction:column;gap:4px}.detail-polygon-heading{font-size:0.84rem;letter-spacing:0.4px;text-transform:uppercase;color:var(--text);line-height:1.25}.detail-polygon-description{color:var(--text-muted);font-size:0.76rem;margin:0;line-height:1.35;white-space:break-spaces}.detail-polygon-controls{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px 8px}.detail-polygon-controls-modal{grid-template-columns:1fr}.detail-polygon-controls .detail-form-group{margin-bottom:0}.detail-polygon-controls .detail-form-group label{font-size:0.62rem;letter-spacing:0.9px;margin-bottom:3px}.detail-polygon-controls .detail-form-group select{padding:7px 9px;font-size:0.78rem;background-position:right 8px center}.detail-polygon-controls .detail-color-select-wrap{position:relative}.detail-polygon-controls .detail-color-select-wrap select{padding-right:138px}.detail-polygon-controls .detail-color-name{margin-top:0;font-size:0.68rem;color:var(--text-muted);line-height:1.25;display:inline-flex;align-items:center;gap:6px;position:absolute;top:50%;right:25px;transform:translateY(-50%);pointer-events:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:calc(100% - 44px)}.detail-polygon-controls .detail-color-swatch{width:11px;height:11px;border-radius:999px;border:1px solid var(--border-dark);flex:0 0 auto}.detail-polygon-footer{margin-top:auto;padding-top:15px;border-top:1px solid var(--border);display:flex;gap:12px;flex-wrap:wrap;font-size:0.74rem;color:var(--text-muted)}.detail-polygon-configure-pill{fill:rgba(255,255,255,0.92);stroke:#c9c3bb;stroke-width:1.4}.detail-polygon-configure-label{fill:#2f2c28;font-family:var(--font);font-size:11px;letter-spacing:0.4px;text-transform:uppercase;pointer-events:none}.detail-form-group{margin-bottom:10px}.detail-form-group label{display:block;font-size:0.75rem;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:6px;color:var(--text-muted)}.detail-form-group select{width:100%;padding:10px 14px;border:1.5px solid var(--border);background:var(--bg);font-family:var(--font);font-size:0.9rem;outline:none;cursor:pointer;transition:var(--transition);-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M6 8L1 3h10z' fill='%236b6b6b'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}.detail-form-group select:focus{border-color:var(--border-dark)}.detail-stitch-sentence{margin:0;font-size:0.76rem;line-height:1.45;color:var(--text-muted)}.detail-actions{display:flex;gap:12px;margin-top:20px}.detail-page-actions{flex-wrap:wrap}.store-view .detail-title-centered{margin-bottom:18px}.store-content{max-width:980px;margin:0 auto}.store-main{max-width:1080px;margin:0 auto}.store-media-shell{display:grid;gap:12px}.store-media-carousel{overflow:hidden;border:1.5px solid var(--border);background:#f5f3ef;outline:none}.store-media-track{display:flex;transition:transform 0.35s ease;will-change:transform}.store-media-slide{min-width:100%;margin:0;aspect-ratio:5 / 4;display:block;place-items:center;background:radial-gradient(circle at top right,rgba(255,255,255,0.72),transparent 32%),linear-gradient(135deg,#f7f3ee 0%,#ede5dc 100%)}.store-media-asset{max-width:100%;max-height:100%;display:block}.store-media-controls{display:flex;align-items:center;justify-content:space-between;gap:12px}.store-media-nav{min-width:48px;justify-content:center}.store-media-nav:disabled{opacity:0.55;cursor:default}.store-media-status{font-size:0.8rem;color:var(--text-muted);letter-spacing:1px;text-transform:uppercase}.store-copy-block{margin-top:0}.store-summary{margin:0 0 10px;font-size:1rem;color:var(--text)}.fav-active{background:var(--bg-dark) !important;color:var(--text-light) !important}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:200;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity 0.25s}.modal-overlay.active{opacity:1;pointer-events:all}.modal{background:var(--bg-card);border:1.5px solid var(--border-dark);width:min(80vw,500px);max-width:500px;max-height:90vh;padding:36px 32px 32px;position:relative;overflow-y:auto;overscroll-behavior:contain;transform:translateY(20px);transition:transform 0.25s}.modal-overlay.active .modal{transform:translateY(0)}.modal-close{position:absolute;top:14px;right:16px;background:none;border:none;font-size:1.2rem;cursor:pointer;color:var(--text-muted);transition:var(--transition)}.modal-close:hover{color:var(--text)}.modal h2{font-family:var(--font-heading);font-size:1.4rem;font-weight:400;margin-bottom:24px}.preferences-modal-intro{margin-bottom:20px;color:var(--text-muted)}.preferences-modal-row{display:grid;grid-template-columns:1fr;gap:20px}.preferences-modal-row .form-group{margin-bottom:18px}.preferences-modal-actions{display:grid;grid-template-columns:1fr;gap:12px}.form-group{margin-bottom:18px}.form-group label{display:block;font-size:0.75rem;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:6px;color:var(--text-muted)}.form-group input,.form-group select{width:100%;padding:10px 14px;border:1.5px solid var(--border);background:var(--bg);font-family:var(--font);font-size:0.9rem;outline:none;transition:var(--transition)}.form-group input:focus,.form-group select:focus{border-color:var(--border-dark)}.form-group textarea{width:100%;min-height:100px;padding:10px 14px;border:1.5px solid var(--border);background:var(--bg);font-family:var(--font);font-size:0.9rem;outline:none;transition:var(--transition);resize:vertical}.form-group textarea:focus{border-color:var(--border-dark)}.contact-user-email{width:100%;min-height:41px;padding:10px 14px;border:1.5px solid var(--border);background:#f3f3f3;font-size:0.9rem;color:var(--text-muted);display:flex;align-items:center}#contactMessage{width:100%;min-height:100px;resize:none}.form-group.checkbox-group{display:flex;align-items:center;justify-content:flex-start}.form-group.checkbox-group input{width:auto;margin-right:10px;cursor:pointer}.form-group.checkbox-group label{display:inline;margin-bottom:0;text-transform:none;letter-spacing:normal;font-size:0.9rem;cursor:pointer}.form-footer{margin-top:24px;display:flex;flex-direction:column;gap:10px}.form-link{font-size:0.82rem;color:var(--text-muted);text-decoration:underline;cursor:pointer;background:none;border:none;font-family:var(--font);text-align:left}.form-link:hover{color:var(--text)}.form-message{font-size:0.82rem;padding:8px 12px;margin-bottom:12px;border:1px solid}.form-message.error{color:#8b0000;border-color:#8b0000;background:#fff0f0}.form-message.success{color:#006400;border-color:#006400;background:#f0fff0}.form-message.info{color:var(--text-muted);border-color:var(--border);background:transparent}.billing-pay-form .billing-form-row{margin-bottom:0}.billing-pay-form .billing-form-row .form-group{margin-bottom:18px}.billing-pay-form #billingPurchaseQuantity:disabled{background:#ebe7e1;border-color:#c9c1b7;color:#6f685f;opacity:1;cursor:not-allowed}.profile-header{margin-bottom:32px;display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:16px}.profile-header h1{font-family:var(--font-heading);font-size:1.8rem;font-weight:400}.profile-header p{color:var(--text-muted);font-size:0.9rem}.profile-section{margin-bottom:40px}.profile-section h2{font-family:var(--font-heading);font-size:1.2rem;font-weight:400;margin-bottom:16px;padding-bottom:8px;border-bottom:1px solid var(--border)}.profile-tabs{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}.profile-tab-btn{border:1.5px solid var(--border);background:var(--bg-card);color:var(--text-muted);font-size:0.78rem;letter-spacing:1px;text-transform:uppercase;padding:10px 14px;cursor:pointer;transition:var(--transition)}.profile-tab-btn:hover{border-color:var(--border-dark);color:var(--text)}.profile-tab-btn.active{background:var(--bg-dark);color:var(--text-light);border-color:var(--border-dark)}.profile-tab-panel{display:none}.profile-tab-panel.active{display:block}.profile-pricing-summary{display:grid;gap:6px;margin-bottom:10px;color:var(--text-muted)}.billing-invoice-list{display:grid;gap:8px;overflow-x:auto}.billing-invoice-item{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr auto;gap:8px;border:1px solid var(--border);background:var(--bg-card);padding:10px 12px;font-size:0.8rem;color:var(--text-muted);align-items:center;min-width:760px}.billing-invoice-item>div{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.billing-invoice-actions{justify-self:end}.profile-role-badge{display:inline-block;font-size:0.7rem;letter-spacing:1.5px;text-transform:uppercase;padding:4px 10px;border:1.5px solid var(--border-dark);margin-left:8px;vertical-align:middle}.empty-state{text-align:center;padding:48px 20px;color:var(--text-muted)}.empty-state i{font-size:2rem;margin-bottom:12px;display:block}#creationsUnavailable .fa-circle-info{margin-bottom:0}.admin-panel{border:1.5px solid var(--border-dark);padding:24px;margin-top:20px}.admin-panel h3{font-family:var(--font-heading);font-weight:400;margin-bottom:16px}.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px}.stat-box{border:1px solid var(--border);padding:16px;text-align:center}.stat-box .number{font-size:1.8rem;font-family:var(--font-heading);display:block}.stat-box .label{font-size:0.72rem;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted)}.creator-item{display:flex;align-items:center;gap:16px;padding:12px 0;border-bottom:1px solid var(--border)}.creator-item-thumb{width:60px;height:60px;background:#e8e5e0;border:1px solid var(--border);flex-shrink:0}.creator-item-info h4{font-family:var(--font-heading);font-weight:400;font-size:0.95rem}.creator-item-info p{font-size:0.78rem;color:var(--text-muted)}.detail-assembly-summary{margin-top:12px;padding:10px 12px;border:1px solid #ded7cf;border-radius:10px;background:#faf7f3}.detail-assembly-summary h3{margin:0 0 6px;font-size:0.95rem}.detail-assembly-list{margin:0;padding-left:18px}.project-actions{margin-top:10px;display:flex;gap:8px;flex-wrap:wrap}.project-profile-card{position:relative}.project-profile-card .pattern-card-body h3{margin-right:40px}.project-card-meta p{margin:0;color:var(--text-muted);font-size:0.78rem;line-height:1.45;display:block}.project-card-menu-wrap{position:absolute;top:10px;right:10px;z-index:5}.project-card-menu-btn{width:32px;height:32px;border:1.5px solid var(--border-dark);background:var(--bg-card);color:var(--text);cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.project-card-menu-btn:hover{background:var(--bg-dark);color:var(--text-light)}.project-card-menu{display:none;position:absolute;top:calc(100% + 6px);right:0;min-width:148px;border:1.5px solid var(--border-dark);background:var(--bg-card);box-shadow:var(--shadow)}.project-card-menu.open{display:block}.project-card-menu button{width:100%;border:0;border-bottom:1px solid var(--border);background:transparent;text-align:left;padding:9px 11px;font-size:0.75rem;letter-spacing:0.4px;text-transform:uppercase;cursor:pointer;color:var(--text)}.project-card-menu button:last-child{border-bottom:0}.project-card-menu button:hover{background:#f1efeb}.project-card-menu button.danger{color:#8b0000}.quote-section{text-align:center;padding:40px 32px;margin-bottom:32px;border-bottom:1px solid var(--border);min-height:184px;display:flex;flex-direction:column;justify-content:center}.quote-section blockquote{font-family:var(--font-heading);font-size:1.05rem;font-style:italic;color:var(--text-muted);max-width:700px;margin:0 auto 12px;line-height:1.7}.quote-section cite{font-size:0.82rem;letter-spacing:1px;color:var(--text-muted)}footer{border-top:2px solid var(--border-dark);padding:24px;text-align:center;font-size:0.78rem;color:var(--text-muted);letter-spacing:1px}.footer-links{margin-top:10px;font-size:0.9em;display:flex;justify-content:center;gap:15px;flex-wrap:wrap}.footer-link{cursor:pointer;color:inherit;text-decoration:underline}@media (max-width:768px){.header-top{padding:6px;gap:10px;display:grid;grid-template-columns:auto minmax(0,1fr) auto;grid-template-areas:"menu logo controls";align-items:center}.logo{font-size:1.15rem;gap:8px;grid-area:logo;min-width:0;justify-self:center;overflow:hidden;text-overflow:ellipsis}.logo-mark{width:28px;height:28px}.hamburger{display:block;grid-area:menu;justify-self:start}.search-container{display:none}.header-controls{grid-area:controls;justify-self:end;min-width:0}.header-controls .btn:not(.btn-icon){height:36px;padding:0 6px;font-size:0.75rem;letter-spacing:0.8px}.header-preferences-btn{min-width:76px;gap:6px}nav{display:none;flex-direction:column;gap:0;padding:0 16px 12px;border-top:1px solid var(--border);background:var(--bg)}nav.open{display:flex}nav a{padding:10px 0;border-bottom:1px solid var(--border)}.mobile-search{display:block;padding:0 16px 12px}.mobile-search input{width:100%;padding:10px 14px;border:1.5px solid var(--border);font-family:var(--font);font-size:0.9rem;outline:none}.detail-view{display:block}.detail-svg-container{height:auto;padding:44px 10px 10px 52px}.detail-reset-polygons{top:auto;left:auto;right:8px;bottom:8px;padding:8px 12px;font-size:0.78rem}.detail-svg-live-stats{min-width:0;max-width:calc(100% - 116px);padding:6px 7px;font-size:0.68rem;line-height:1.25}.detail-svg-live-stats-row{gap:4px;flex-direction:column;align-items:flex-start}.pattern-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.detail-stitch-sentence{font-size:0.74rem;line-height:1.4}.profile-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.profile-tab-btn{width:100%;text-align:center}.detail-polygon-controls .detail-color-select-wrap select{padding-right:120px}.detail-polygon-controls .detail-color-name{right:22px;max-width:calc(100% - 40px)}.detail-variant-switch{position:static;width:100%;max-width:100%;margin-bottom:10px}.detail-actions .btn{flex:1 1 calc(50% - 6px);min-width:140px}.detail-page-actions .btn{flex:1 1 100%;min-width:0}.store-media-slide{aspect-ratio:1 / 1}.store-media-controls{gap:10px}.store-media-nav{min-width:42px}.tool-card{flex-basis:clamp(170px,72vw,220px);min-height:72px;padding:8px;gap:8px;align-items:center}.tool-card-icon{width:28px;height:28px}.tool-card-label{font-size:0.78rem}.tools-selector{display:grid;gap:10px}.tools-selector-head{justify-content:space-between;margin-bottom:0}.tool-nav-btn{width:40px;height:40px}.tools-carousel{scroll-padding-inline:16px}.tools-selected-summary{padding:8px 10px}.tool-workspace{padding:12px}.tool-panel p{margin-bottom:10px}.tool-form-row .tool-field{flex:1 1 100%;min-width:0}.tool-form-row{flex-direction:column;overflow-x:visible;padding-bottom:0}.tool-field{flex-direction:row;align-items:center;gap:10px}.tool-field span{flex:0 0 min(44%,150px)}.tool-field input,.tool-field select{flex:1 1 auto}main{padding:20px 16px 40px}.billing-pay-form .billing-form-row-mobile-dual{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.billing-pay-form .billing-form-row-mobile-dual .form-group{margin-bottom:12px}}@media (max-width:430px){.billing-pay-form .billing-form-row-mobile-dual{grid-template-columns:1fr}}@media (min-width:769px){.mobile-search{display:none}.preferences-modal-row{grid-template-columns:repeat(2,minmax(0,1fr))}.preferences-modal-actions{grid-template-columns:repeat(2,minmax(0,1fr))}.billing-pay-form .billing-form-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}.billing-pay-form .billing-form-row-payment{grid-template-columns:minmax(0,1fr) minmax(110px,160px)}.billing-pay-form .billing-form-row-country-org{grid-template-columns:minmax(88px,120px) minmax(0,1fr)}.billing-pay-form .billing-form-group-quantity input{text-align:right}.billing-pay-form .billing-label-nowrap{white-space:nowrap}.billing-pay-form .billing-form-row .form-group{margin-bottom:18px}}.pattern-grid.scattered{display:block;column-count:3;column-gap:24px}.pattern-grid.scattered .pattern-card{break-inside:avoid;margin-bottom:24px}@media (max-width:900px){.pattern-grid.scattered{column-count:2}}@media (max-width:560px){.pattern-grid.scattered{column-count:1}.detail-polygon-controls-modal{grid-template-columns:1fr}}@media (min-width:769px){.form-row{display:flex;gap:20px}.form-row .form-group{flex:1}}.detail-polygon-controls .detail-color-select-wrap select{padding-left:30px;padding-right:30px}.detail-polygon-controls .detail-color-select-wrap .detail-color-swatch{width:11px;height:11px;border-radius:999px;border:1px solid var(--border-dark);position:absolute;top:50%;left:10px;transform:translateY(-50%);pointer-events:none}.detail-polygon-controls .detail-form-group[data-detail-control-locked="true"] label{color:#7c756d}.detail-polygon-controls .detail-form-group[data-detail-control-locked="true"]{position:relative}.detail-polygon-controls .detail-form-group[data-detail-control-locked="true"] select[disabled]{border-color:#c9c1b7;background-color:#ebe7e1;color:#6f685f;cursor:not-allowed;opacity:1;box-shadow:inset 0 0 0 1px rgba(130,121,109,0.12);padding-right:72px}.detail-polygon-controls .detail-form-group[data-detail-control-locked="true"]::after{content:"Locked";position:absolute;right:24px;bottom:11px;font-size:0.6rem;letter-spacing:0.5px;line-height:1.1;color:#6f685f;text-transform:uppercase;pointer-events:none;opacity:0.9}@media (max-width:768px){.detail-polygon-controls{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:560px){.detail-polygon-controls{grid-template-columns:1fr}.detail-actions .btn{width:100%;min-width:0}}.creations-page{display:flex;flex-direction:column;gap:24px}.creations-header{margin-bottom:0}.creations-layout{display:grid;grid-template-columns:minmax(0,1fr);gap:24px;align-items:start}.creations-main{min-width:0}.creations-saved-strip,.creations-form-section{margin-bottom:0}.creations-sidebar-header,.creations-actions{display:flex;align-items:center;gap:12px;justify-content:space-between;flex-wrap:wrap}.creations-form-section .form-row{margin-bottom:-10px}#creationsForm{padding-top:10px;padding-bottom:10px}.creations-primary-actions{flex:0 1 auto;min-width:0;margin-left:auto}.creations-dimension-field{flex:0 0 140px;max-width:160px}.creations-actions-label{display:none}.creations-actions-primary{margin-top:0;justify-content:flex-end;flex-wrap:nowrap;gap:10px}.creations-split-btn{position:relative;display:inline-flex}.creations-split-btn>#creationSaveBtn{border-right:none}.creations-split-toggle{padding:8px 10px;border-left:1px solid rgba(26,26,26,0.22)}.creations-split-menu{position:absolute;top:100%;left:0;min-width:100%;background:var(--bg-card);border:1.5px solid var(--border-dark);z-index:20;display:flex;flex-direction:column}.creations-split-menu[hidden]{display:none}.creations-split-menu button{width:100%;padding:10px 16px;text-align:left;background:transparent;border:none;border-bottom:1px solid var(--border);font-family:var(--font);font-size:0.82rem;letter-spacing:1px;text-transform:uppercase;cursor:pointer;white-space:nowrap;color:var(--text);transition:var(--transition)}.creations-split-menu button:last-child{border-bottom:none}.creations-split-menu button:hover{background:var(--bg-dark);color:var(--text-light)}.creations-split-menu button:disabled{opacity:0.38;cursor:default;pointer-events:none}.creations-card-list{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(220px,280px);gap:12px;overflow-x:auto;overflow-y:hidden;padding-bottom:6px;align-items:stretch}.creations-card{cursor:default}.creations-card.is-active{border-color:var(--border-dark);box-shadow:var(--shadow)}.creations-card .pattern-card-body{display:grid;gap:10px}.creations-card .pattern-card-body p{-webkit-line-clamp:unset}.creations-editor-shell{position:relative;min-height:0;border:1.5px solid var(--border-dark);background:linear-gradient(135deg,rgba(255,255,255,0.92),rgba(242,237,230,0.92)),radial-gradient(circle at top right,rgba(209,236,241,0.45),transparent 38%);box-shadow:var(--shadow);overflow:hidden}.creations-editor-stage{position:relative;display:flex;height:clamp(620px,75vh,1150px);min-height:clamp(620px,75vh,1150px)}.creations-selected-polygon{display:flex;align-items:center;gap:10px;flex:0 0 auto}.creations-properties-trigger{min-width:42px;min-height:42px;padding:0 12px}.creations-properties-color-input{width:100%;min-height:44px;padding:4px}.creations-canvas-shell{position:relative;flex:1 1 auto;min-height:0;padding:0;overflow:hidden;display:flex;align-items:stretch;justify-content:stretch;background:linear-gradient(180deg,rgba(250,249,247,0.55),rgba(255,255,255,0.92))}.creations-message-host{min-height:44px;display:flex;align-items:flex-start;gap:10px;padding-top:4px;width:100%}.creations-help-trigger{width:42px;min-width:42px;min-height:42px;padding:0;display:inline-flex;align-items:center;justify-content:center;font-size:1rem;color:var(--text-muted)}.creations-help-trigger:hover{color:var(--text-light)}.creations-help-trigger-unavailable{margin-top:14px;width:auto;padding:0 14px;gap:8px;align-items:center;justify-content:center;line-height:1}.creations-help-trigger-unavailable span{display:inline-flex;align-items:center;line-height:1}#creationsMessage{width:100%}.creations-message-host .form-message{margin-bottom:0}.creations-help-intro{margin-bottom:16px;color:var(--text-muted)}.creations-help-list{margin:0;padding-left:20px;display:grid;gap:10px;color:var(--text)}.creations-trashcan-overlay{position:absolute;right:20px;bottom:20px;z-index:2;display:flex;justify-content:flex-end;pointer-events:none}.creations-trashcan{width:62px;height:62px;display:inline-flex;align-items:center;justify-content:center;border:1.5px solid var(--border-dark);background:rgba(255,255,255,0.92);color:var(--text);box-shadow:var(--shadow);pointer-events:none;transition:transform var(--transition),background var(--transition),color var(--transition),opacity var(--transition)}.creations-trashcan.is-disabled{opacity:0.35}.creations-trashcan i{font-size:1.2rem}.creations-trashcan.drag-over{background:var(--bg-dark);color:var(--text-light);transform:scale(1.08)}.creations-canvas{width:100%;height:100%;display:block;border:1px solid var(--border);background:linear-gradient(180deg,rgba(255,255,255,0.95),rgba(246,242,236,0.95))}.creations-grid-line{stroke:rgba(107,107,107,0.16);stroke-width:1}.creations-polygon{stroke:rgba(26,26,26,0.68);stroke-width:2.5;fill-opacity:0.88;cursor:move;transition:opacity var(--transition),stroke-width var(--transition)}.creations-polygon.is-selected{stroke:var(--border-dark);stroke-width:4}.creations-vertex-handle{fill:#fff;stroke:rgba(26,26,26,0.72);stroke-width:2;cursor:pointer}.creations-vertex-handle.is-selected{fill:#f6f2ec;stroke-width:2.5}.creations-preview-point{fill:rgba(22,163,74,0.28);stroke:#15803d;stroke-width:2;pointer-events:none}.creations-draft-line{fill:none;stroke:#6c7a89;stroke-width:3;stroke-dasharray:8 6}.creations-draft-point{fill:#6c7a89;stroke:#fff;stroke-width:2;cursor:pointer}.creations-draft-point.is-active{fill:#16a34a;stroke:#f6f2ec;stroke-width:3}.creations-canvas.is-dragging-polygon,.creations-canvas.is-dragging-polygon .creations-polygon{cursor:move}.creations-save-dirty{box-shadow:inset 0 0 0 1px rgba(255,255,255,0.18),0 0 0 3px rgba(26,26,26,0.18)}.creations-unavailable{border:1.5px solid var(--border-dark);background:var(--bg-card)}@media (max-width:1180px){.creations-form-section .form-row{flex-wrap:wrap}.creations-primary-actions{flex:1 1 100%;margin-left:0}.creations-dimension-field{flex:1 1 120px;max-width:none}.creations-actions-primary{justify-content:flex-start;flex-wrap:wrap}.creations-card-list{grid-auto-columns:minmax(220px,260px)}}