*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#7c3aed;--primary-hover:#6d28d9;--primary-light:#ede9fe;--primary-mid:#a78bfa;--secondary:#8baf95;--danger:#ef4444;--danger-hover:#dc2626;--bg:#f9f7ff;--surface:#fff;--surface-tint:#f5f3ff;--border:#e5e7eb;--border-mid:#d1d5db;--text:#1f2937;--text-muted:#6b7280;--text-subtle:#9ca3af;--shadow-sm:0 2px 8px #6d28d912;--shadow:0 4px 24px #6d28d914;--shadow-lg:0 20px 60px #6d28d91f;--radius:8px;--radius-lg:16px}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:DM Sans,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5}h1,h2,h3{font-family:Lora,serif}button{cursor:pointer;border-radius:var(--radius);font-family:inherit;font-size:14px;line-height:1;transition:background .15s,opacity .15s}button:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff;border:none;padding:9px 18px;font-weight:600}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-outline{color:var(--text);border:1.5px solid var(--border-mid);background:0 0;padding:8px 16px;font-weight:500}.btn-outline:hover{border-color:#9ca3af}.btn-danger{background:var(--danger);color:#fff;border:none;padding:9px 18px;font-weight:600}.btn-danger:hover{background:var(--danger-hover)}.btn-sm{padding:6px 12px;font-size:13px}.btn-full{width:100%}label{color:var(--text-muted);letter-spacing:.02em;flex-direction:column;gap:5px;font-size:13px;font-weight:600;display:flex}input[type=text],input[type=password],input[type=number]{border:1.5px solid var(--border);border-radius:var(--radius);color:var(--text);background:var(--surface);outline:none;padding:9px 12px;font-family:inherit;font-size:14px;transition:border-color .15s}input:focus{border-color:var(--primary)}.error{color:var(--danger);border-radius:var(--radius);background:#fef2f2;padding:8px 10px;font-size:13px}.form-hint{color:var(--text-muted);font-size:12px}.navbar{background:var(--bg);border-bottom:1px solid var(--border);z-index:100;align-items:center;height:57px;padding:0 32px;display:flex;position:sticky;top:0}.nav-brand{color:var(--text);flex-shrink:0;align-items:center;gap:8px;font-family:Lora,serif;font-size:18px;font-weight:700;text-decoration:none;display:flex}.nav-center{align-items:center;gap:28px;margin:0 auto;display:flex}.nav-right{flex-shrink:0;align-items:center;gap:12px;display:flex}.nav-user{color:var(--text-muted);font-size:13px}button.nav-user{cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit}button.nav-user:hover{color:var(--primary);text-decoration:underline}.auth-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-card{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:400px;box-shadow:var(--shadow-lg);flex-direction:column;gap:22px;padding:40px;display:flex}.auth-header{text-align:center}.auth-logo{color:var(--primary);letter-spacing:-.02em;justify-content:center;align-items:center;gap:10px;margin-bottom:6px;font-family:Lora,serif;font-size:32px;font-weight:700;display:flex}.auth-tagline{color:var(--text-muted);font-size:14px}.tab-bar{background:var(--bg);border-radius:var(--radius);gap:2px;padding:3px;display:flex}.tab-bar button{color:var(--text-muted);background:0 0;border:none;border-radius:6px;flex:1;padding:8px;font-weight:500}.tab-bar .tab-active{background:var(--surface);color:var(--primary);box-shadow:var(--shadow-sm)}.auth-card form{flex-direction:column;gap:14px;display:flex}.page{flex-direction:column;min-height:100vh;display:flex}.page--fill{height:100vh;overflow:hidden}.dashboard-layout{flex:1;min-height:0;display:flex;overflow:hidden}.folder-sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:2px;width:216px;padding:14px 8px;display:flex;overflow-y:auto}.folder-sidebar-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);justify-content:space-between;align-items:center;margin-bottom:8px;padding:0 8px;font-size:10px;font-weight:700;display:flex}.folder-new-btn{width:22px;height:22px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:0;font-size:18px;line-height:1;transition:background .12s,color .12s;display:flex}.folder-new-btn:hover{background:var(--border);color:var(--text)}.folder-item{cursor:pointer;color:var(--text);text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:6px;width:100%;padding:6px 8px;font-size:13px;transition:background .1s;display:flex}.folder-item:hover{background:var(--bg)}.folder-item--active{background:var(--primary-light);color:var(--primary);font-weight:600}.folder-item--active:hover{background:var(--primary-light)}.folder-item-icon{flex-shrink:0;font-size:14px}.folder-item-name{text-overflow:ellipsis;white-space:nowrap;text-align:left;flex:1;overflow:hidden}.folder-item-count{color:var(--text-muted);background:var(--border);border-radius:10px;flex-shrink:0;padding:1px 6px;font-size:11px}.folder-item--active .folder-item-count{color:var(--primary);background:#c4714b26}.folder-item-actions{opacity:0;flex-shrink:0;gap:1px;transition:opacity .12s;display:flex}.folder-item:hover .folder-item-actions,.folder-item--active .folder-item-actions{opacity:1}.folder-action-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:4px;padding:2px 5px;font-size:12px;line-height:1;transition:background .1s,color .1s}.folder-action-btn:hover{color:var(--text);background:#0000000f}.folder-action-btn--danger:hover{color:var(--danger);background:#fee2e2}.folder-name-input{border:1.5px solid var(--primary);background:var(--surface);border-radius:4px;outline:none;flex:1;min-width:0;padding:1px 6px;font-family:inherit;font-size:13px}.folder-create-input{border:1.5px dashed var(--border);background:var(--bg);width:100%;color:var(--text);border-radius:6px;outline:none;margin-top:4px;padding:6px 10px;font-family:inherit;font-size:13px;transition:border-color .15s,background .15s}.folder-create-input:focus{border-color:var(--primary);background:var(--surface)}.dashboard-main{flex:1;min-width:0;overflow-y:auto}.dashboard{width:100%;max-width:1100px;margin:0 auto;padding:36px 24px}.pattern-folder-tag{color:var(--text-muted);align-items:center;gap:4px;margin-top:2px;font-size:11px;display:flex}.move-menu{position:relative}.move-dropdown{z-index:200;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-lg);border-radius:8px;flex-direction:column;gap:1px;min-width:170px;padding:4px;display:flex;position:absolute;top:calc(100% + 4px);left:0}.move-dropdown-btn{color:var(--text);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:5px;align-items:center;gap:8px;width:100%;padding:7px 10px;font-size:13px;transition:background .1s;display:flex}.move-dropdown-btn:hover{background:var(--bg)}.move-dropdown-empty{color:var(--text-muted);text-align:center;padding:8px 10px;font-size:12px}.dashboard-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:32px;display:flex}.dashboard-header h1{letter-spacing:-.02em;font-size:26px;font-weight:800}.dashboard-subtitle{color:var(--text-muted);margin-top:2px;font-size:14px}.patterns-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px;display:grid}.empty-state{text-align:center;color:var(--text-muted);flex-direction:column;align-items:center;gap:14px;padding:80px 24px;display:flex}.empty-icon{font-size:56px}.empty-state h2{color:var(--text);font-size:20px}.empty-state p{font-size:14px}.pattern-card{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:box-shadow .15s,transform .1s;overflow:hidden}.pattern-card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.pattern-card--gallery:hover{transform:translateY(-3px);box-shadow:0 8px 28px #6d28d924}.pattern-preview{background:var(--surface-tint);cursor:pointer;justify-content:center;align-items:center;height:180px;text-decoration:none;display:flex;overflow:hidden}.pattern-meta{padding:14px 16px}.pattern-name{white-space:nowrap;text-overflow:ellipsis;margin-bottom:3px;font-size:15px;font-weight:700;overflow:hidden}.pattern-dims{color:var(--text-muted);margin-bottom:12px;font-size:12px}.card-actions{gap:8px;display:flex}.type-label{color:var(--text-muted);letter-spacing:.02em;margin-bottom:6px;font-size:13px;font-weight:600}.type-cards{grid-template-columns:1fr 1fr;gap:8px;display:grid}.type-card{border:2px solid var(--border);border-radius:var(--radius);background:var(--surface);text-align:left;cursor:pointer;flex-direction:column;gap:4px;padding:12px;transition:border-color .15s,background .15s;display:flex}.type-card:hover{border-color:var(--primary-light);background:var(--bg)}.type-card--active{border-color:var(--primary);background:var(--primary-light)}.type-card-title{color:var(--text);font-size:13px;font-weight:700}.type-card--active .type-card-title{color:var(--primary)}.type-card-desc{color:var(--text-muted);font-size:11px;line-height:1.4}.modal-overlay{z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000073;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:440px;box-shadow:var(--shadow-lg);padding:32px}.modal h2{margin-bottom:22px;font-size:20px;font-weight:800}.modal form{flex-direction:column;gap:14px;display:flex}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.modal-actions{justify-content:flex-end;gap:10px;padding-top:6px;display:flex}.modal-backdrop{z-index:300;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000073;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.cpm{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);flex-direction:column;width:100%;max-width:480px;max-height:90vh;display:flex;overflow:hidden}.cpm-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:flex-start;padding:22px 24px 16px;display:flex}.cpm-title{color:var(--text);margin:0 0 3px;font-family:Lora,serif;font-size:20px;font-weight:700}.cpm-subtitle{color:var(--text-subtle);margin:0;font-family:DM Sans,system-ui,sans-serif;font-size:13px}.cpm-close-btn{color:var(--text-subtle);cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;padding:4px;transition:background .12s,color .12s;display:flex}.cpm-close-btn:hover{background:var(--bg);color:var(--text)}.cpm-list{flex:1;padding:8px 0;overflow-y:auto}.cpm-empty{text-align:center;color:var(--text-subtle);padding:24px;font-family:DM Sans,system-ui,sans-serif;font-size:14px}.cpm-row{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:10px 24px;transition:background .1s;display:flex}.cpm-row:last-child{border-bottom:none}.cpm-row:hover{background:var(--bg)}.cpm-row--unused{opacity:.65}.cpm-swatch-wrap{cursor:pointer;flex-shrink:0;position:relative}.cpm-swatch{border-radius:8px;width:36px;height:36px;transition:transform .1s;display:block}.cpm-swatch-wrap:hover .cpm-swatch{transform:scale(1.08)}.cpm-color-input{opacity:0;cursor:pointer;border:none;width:100%;height:100%;padding:0;position:absolute;inset:0}.cpm-info{flex:1;min-width:0}.cpm-name-input{width:100%;color:var(--text);box-sizing:border-box;background:0 0;border:none;border-bottom:1.5px solid #0000;outline:none;padding:0 0 2px;font-family:DM Sans,system-ui,sans-serif;font-size:14px;font-weight:500;transition:border-color .15s}.cpm-name-input:focus{border-bottom-color:var(--primary)}.cpm-name-input::placeholder{color:var(--text-subtle);font-weight:400}.cpm-meta{align-items:center;gap:5px;margin-top:4px;display:flex}.cpm-hex{color:var(--text-subtle);text-transform:uppercase;letter-spacing:.03em;font-family:DM Sans,system-ui,sans-serif;font-size:11px}.cpm-dot-sep{color:var(--text-subtle);font-size:11px}.cpm-count{color:var(--text-subtle);font-family:DM Sans,system-ui,sans-serif;font-size:11px}.cpm-count--unused{color:#ef4444;font-style:italic}.cpm-remove-btn{color:var(--text-subtle);cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;padding:6px;transition:background .12s,color .12s;display:flex}.cpm-remove-btn:hover:not(:disabled){color:#ef4444;background:#fee2e2}.cpm-remove-btn:disabled{opacity:.3;cursor:not-allowed}.cpm-footer{border-top:1px solid var(--border);background:var(--bg);flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:10px;padding:16px 24px;display:flex}.cpm-footer-left{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.cpm-add-btn{background:var(--primary-light);color:var(--primary);border-radius:var(--radius);cursor:pointer;border:none;align-items:center;gap:6px;padding:8px 14px;font-family:DM Sans,system-ui,sans-serif;font-size:13px;font-weight:500;transition:background .12s;display:inline-flex;position:relative;overflow:hidden}.cpm-add-btn:hover{background:#ddd6fe}.cpm-cleanup-btn{color:#ef4444;border-radius:var(--radius);cursor:pointer;background:#fee2e2;border:none;align-items:center;gap:6px;padding:8px 14px;font-family:DM Sans,system-ui,sans-serif;font-size:13px;font-weight:500;transition:background .12s;display:inline-flex}.cpm-cleanup-btn:hover{background:#fecaca}.cpm-done-btn{white-space:nowrap;padding:9px 22px;font-size:14px}.editor{flex-direction:column;height:100vh;display:flex;overflow:hidden}.editor-header{background:var(--bg);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:10px;height:57px;padding:0 20px;display:flex}.eh-icon-btn{cursor:pointer;width:30px;height:30px;color:var(--text-muted);background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;transition:background .12s,color .12s;display:flex}.eh-icon-btn:hover{background:var(--surface-tint);color:var(--text)}.eh-icon-btn:disabled{opacity:.35;cursor:default}.eh-logo{cursor:pointer;flex-shrink:0;align-items:center;gap:9px;display:flex}.eh-logo span{color:var(--text);font-family:Lora,serif;font-size:18px;font-weight:700;line-height:1}.eh-divider{background:var(--border);flex-shrink:0;width:1px;height:24px}.eh-filename{background:var(--surface-tint);border:1px solid var(--border);border-radius:7px;flex-shrink:1;align-items:center;gap:6px;min-width:0;max-width:240px;padding:5px 10px;display:flex}.eh-filename-text{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font:500 13px DM Sans,sans-serif;overflow:hidden}.eh-filename-input{color:var(--text);background:0 0;border:none;outline:none;width:100%;min-width:80px;max-width:180px;font:500 13px DM Sans,sans-serif}.eh-undo-redo{flex-shrink:0;gap:2px;display:flex}.eh-nav-links{flex-shrink:0;align-items:center;gap:20px;display:flex}.eh-user{flex-shrink:0;align-items:center;gap:10px;display:flex}.eh-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.eh-panel-toggle{display:none}.eh-actions .btn-outline:hover{background:var(--bg)}.editor-left-toolbar{background:var(--bg);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;align-items:center;gap:4px;width:52px;padding:12px 0;display:flex;overflow-y:auto}.lti-btn{width:36px;height:36px;color:var(--text-subtle);cursor:pointer;background:0 0;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;transition:background .12s,color .12s;display:flex}.lti-btn:hover{background:var(--surface-tint);color:var(--primary)}.lti-btn--active{background:var(--primary-light);color:var(--primary)}.lti-divider{background:var(--border);width:28px;height:1px;margin:6px 0}.unsaved-badge{color:var(--text-muted);background:#fef9c3;border-radius:99px;padding:3px 8px;font-size:12px;font-weight:500}.editor-body{flex:1;display:flex;overflow:hidden}.editor-right-panel{background:var(--bg);border-left:1px solid var(--border);flex-direction:column;flex-shrink:0;width:244px;display:flex;overflow-y:auto}.rp-section{border-bottom:1px solid var(--border);padding:16px}.rp-section:last-child{border-bottom:none}.rp-section-head{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.rp-section-title{color:var(--text);letter-spacing:.03em;font:600 12px DM Sans,sans-serif;display:block}.rp-add-btn{background:var(--primary-light);color:var(--primary);cursor:pointer;border:none;border-radius:6px;flex-shrink:0;align-items:center;gap:4px;padding:4px 8px;font:500 11px DM Sans,sans-serif;display:flex}.rp-add-btn:hover{background:#c4714b38}.color-item{cursor:pointer;border:1.5px solid #0000;border-radius:8px;align-items:center;gap:10px;margin-bottom:6px;padding:8px 10px;transition:border-color .12s,background .12s;display:flex}.color-item:last-of-type{margin-bottom:0}.color-item:hover{background:var(--surface-tint)}.color-item--active{border-color:var(--primary);background:#fff5f0}.color-item-swatch{border-radius:5px;flex-shrink:0;width:22px;height:22px}.color-item-info{flex:1;min-width:0}.color-item-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font:500 12px DM Sans,sans-serif;overflow:hidden}.color-item-count{color:var(--text-muted);margin-top:1px;font:300 10px DM Sans,sans-serif}.color-item-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.rp-grid-size{gap:8px;display:flex}.rp-grid-size-field{flex:1}.rp-label{color:var(--text-muted);margin-bottom:4px;font:400 10px DM Sans,sans-serif}.rp-stepper{background:var(--surface-tint);border:1px solid var(--border);border-radius:7px;align-items:center;display:flex;overflow:hidden}.rp-stepper-btn{width:28px;height:30px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;font-size:16px;transition:background .1s;display:flex}.rp-stepper-btn:hover:not(:disabled){background:var(--primary-light);color:var(--primary)}.rp-stepper-btn:disabled{opacity:.35;cursor:default}.rp-stepper-val{text-align:center;color:var(--text);flex:1;font:500 13px DM Sans,sans-serif}.rp-total-label{color:var(--text-muted);margin-bottom:10px;font:300 11px DM Sans,sans-serif}.stitch-bar-item{margin-bottom:10px}.stitch-bar-item:last-child{margin-bottom:0}.stitch-bar-header{justify-content:space-between;align-items:center;gap:6px;margin-bottom:4px;display:flex}.stitch-bar-swatch{border-radius:3px;flex-shrink:0;width:10px;height:10px}.stitch-bar-name{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;max-width:60%;font:400 11px DM Sans,sans-serif;overflow:hidden}.stitch-bar-count{color:var(--text);font:500 11px DM Sans,sans-serif}.stitch-bar{background:var(--surface-tint);border-radius:3px;height:6px;overflow:hidden}.stitch-bar-fill{border-radius:3px;min-width:2px;height:100%;transition:width .3s}.editor-statusbar{background:var(--bg);border-top:1px solid var(--border);height:28px;color:var(--text-subtle);flex-shrink:0;align-items:center;padding:0 16px;font:400 10px DM Sans,sans-serif;display:flex}.sb-sep{color:var(--border);margin:0 14px}.sb-empty{color:var(--border)}.sidebar-section{border-bottom:1px solid var(--border);padding:10px 0}.sidebar-section:last-child{border-bottom:none}.sidebar-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:8px;font-size:10px;font-weight:700}.tool-list{flex-direction:column;gap:3px;display:flex}.tool-btn{border:1.5px solid var(--border);border-radius:var(--radius);color:var(--text);text-align:left;background:0 0;align-items:center;gap:8px;padding:8px 10px;font-size:13px;font-weight:500;transition:all .12s;display:flex}.tool-btn:hover{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.tool-btn--active{background:var(--primary);color:#fff;border-color:var(--primary)}.tool-btn--active:hover{background:var(--primary-hover)}.zoom-row{align-items:center;gap:8px;display:flex}.zoom-btn{border:1.5px solid var(--border);background:var(--surface);width:30px;height:30px;color:var(--text);border-radius:6px;justify-content:center;align-items:center;font-size:18px;font-weight:700;display:flex}.zoom-btn:hover:not(:disabled){background:var(--primary-light);border-color:var(--primary)}.zoom-val{color:var(--text-muted);text-align:center;font-variant-numeric:tabular-nums;min-width:36px;font-size:13px}.color-preview{border-radius:var(--radius);background-image:repeating-conic-gradient(#ccc 0% 25%,#0000 0% 50%);background-size:12px 12px;border:1.5px solid #0000001f;align-items:center;height:38px;margin-bottom:10px;padding:0 10px;display:flex}.color-hex{letter-spacing:.02em;background:#ffffffd1;border-radius:4px;padding:2px 5px;font-family:monospace;font-size:11px;font-weight:600}.palette-grid{grid-template-columns:repeat(5,1fr);gap:5px;margin-bottom:8px;display:grid}.swatch{aspect-ratio:1;cursor:pointer;background-image:repeating-conic-gradient(#ccc 0% 25%,#0000 0% 50%);background-size:8px 8px;border:2px solid #0000;border-radius:5px;width:100%;transition:transform .1s,border-color .1s,box-shadow .1s}.swatch:hover{transform:scale(1.12)}.swatch--active{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.swatch--add{background:var(--bg);color:var(--text-muted);border:1.5px dashed var(--border);background-image:none;justify-content:center;align-items:center;font-size:18px;font-weight:700;line-height:1;display:flex}.swatch--add:hover{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.hidden-color-input{opacity:0;pointer-events:none;width:0;height:0;position:absolute}.hint{color:var(--text-muted);margin-top:4px;font-size:11px}.sidebar-info{color:var(--text-muted);flex-direction:column;gap:3px;font-size:12px;display:flex}.grid-size-control{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.grid-size-label{color:var(--text);font-size:12px;font-weight:500}.grid-size-stepper{align-items:center;gap:6px;display:flex}.grid-size-btn{border:1.5px solid var(--border);width:26px;height:26px;color:var(--text);cursor:pointer;background:0 0;border-radius:5px;justify-content:center;align-items:center;font-size:15px;font-weight:600;line-height:1;transition:all .12s;display:flex}.grid-size-btn:hover{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.grid-size-btn:disabled{opacity:.35;cursor:default;pointer-events:none}.grid-size-val{text-align:center;min-width:26px;color:var(--text);font-size:13px;font-weight:600}.grid-row-strip{flex-direction:column;width:20px;display:flex;position:absolute}.grid-col-strip{height:20px;display:flex;position:absolute}.grid-del-btn{color:var(--primary);cursor:pointer;background:#c4714b12;border:none;flex-shrink:0;justify-content:center;align-items:center;min-width:0;min-height:0;padding:0;font-size:11px;font-weight:700;transition:background .1s;display:flex}.grid-row-strip .grid-del-btn{border-left:1px solid var(--border);width:20px}.grid-col-strip .grid-del-btn{border-top:1px solid var(--border);height:20px}.grid-del-btn:hover{background:#c4714b47}.canvas-area{background:#dde1f0 radial-gradient(circle,#c4b5fd 1px,#0000 1px) 0 0/16px 16px;flex:1;display:flex;position:relative;overflow:auto}.canvas-pad{-webkit-user-select:none;user-select:none;margin:auto;padding:48px}.canvas-zoom-badge{color:#fff;pointer-events:none;z-index:10;white-space:nowrap;background:#4c1d9599;border-radius:20px;padding:4px 10px;font:400 11px DM Sans,sans-serif;position:absolute;bottom:16px;left:50%;transform:translate(-50%)}.canvas-area canvas{box-shadow:0 8px 32px #6d28d92e}.loading-screen{background:var(--bg);justify-content:center;align-items:center;height:100vh;display:flex}.loading-spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:36px;height:36px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.dashboard-loading{justify-content:center;padding:80px;display:flex}.info-msg{color:#15803d;border-radius:var(--radius);background:#dcfce7;padding:8px 10px;font-size:13px}.not-found{height:100vh;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.admin-page{background:var(--bg);min-height:100vh;padding-bottom:64px}.admin-page-heading{padding:24px 32px 0}.admin-title{color:var(--text);font-family:Lora,serif;font-size:22px;font-weight:600}.admin-stats{grid-template-columns:repeat(4,1fr);gap:16px;padding:24px 32px;display:grid}.admin-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px}.admin-stat-num{color:var(--primary);margin-bottom:6px;font-size:32px;font-weight:700;line-height:1}.admin-stat-label{color:var(--text-muted);font-size:12px;font-weight:500}.admin-toolbar{justify-content:space-between;align-items:center;padding:0 32px 16px;display:flex}.admin-search{border:1.5px solid var(--border);border-radius:var(--radius);background:var(--surface);width:280px;color:var(--text);outline:none;padding:8px 12px;font-size:13px}.admin-search:focus{border-color:var(--primary)}.admin-count{color:var(--text-muted);font-size:12px}.admin-table-wrap{padding:0 32px;overflow-x:auto}.admin-table{border-collapse:collapse;background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);width:100%;font-size:13px;overflow:hidden}.admin-th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);background:var(--surface-tint);border-bottom:1px solid var(--border);white-space:nowrap;padding:10px 16px;font-size:11px;font-weight:600}.admin-th--sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.admin-th--sortable:hover{color:var(--text)}.admin-sort-icon{opacity:.4;margin-left:4px;font-size:11px}.admin-sort-icon--active{opacity:1;color:var(--primary)}.admin-tr:hover td{background:var(--surface-tint)}.admin-td{border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;padding:12px 16px}.admin-tr:last-child .admin-td{border-bottom:none}.admin-td--email{font-weight:500}.admin-td--muted{color:var(--text-muted)}.admin-td--num{font-variant-numeric:tabular-nums;color:var(--text)}.admin-login-date{font-size:12px;display:block}.admin-login-ago{color:var(--text-muted);margin-top:1px;font-size:11px;display:block}.admin-shared-badge{background:var(--primary-light);color:var(--primary);border-radius:99px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.nav-link--admin{text-transform:uppercase;letter-spacing:.06em;font-size:11px;font-weight:600;color:var(--primary)!important}.admin-patterns-btn{cursor:pointer;color:var(--primary);border-radius:var(--radius);background:0 0;border:none;padding:2px 6px;font-size:14px;font-weight:600;transition:background .15s}.admin-patterns-btn:hover{background:var(--primary-light)}.admin-view-link{color:var(--primary);font-size:12px;font-weight:600;text-decoration:none}.admin-view-link:hover{text-decoration:underline}.admin-modal-backdrop{z-index:200;background:#00000073;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.admin-modal{background:var(--surface);border-radius:var(--radius-lg);flex-direction:column;width:100%;max-width:760px;max-height:80vh;display:flex;box-shadow:0 8px 40px #00000038}.admin-modal-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:flex-start;padding:24px 24px 16px;display:flex}.admin-modal-title{color:var(--text);margin-bottom:2px;font-family:Lora,serif;font-size:20px}.admin-modal-sub{color:var(--text-muted);font-size:13px}.admin-modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:22px;line-height:1}.admin-modal-close:hover{color:var(--text)}.admin-modal .admin-table-wrap{padding:0;overflow-y:auto}.admin-modal .admin-table{min-width:560px}@media (width<=640px){.admin-stats{grid-template-columns:repeat(2,1fr);padding:16px}.admin-page-heading{padding:16px 16px 0}.admin-toolbar{padding:0 16px 12px}.admin-search{width:100%}.admin-table-wrap{padding:0 16px}}.instr-modal{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:680px;max-height:90vh;box-shadow:var(--shadow-lg);flex-direction:column;display:flex;overflow:hidden}.instr-header{flex-shrink:0;justify-content:space-between;align-items:flex-start;padding:24px 24px 0;display:flex}.instr-header h2{font-size:20px;font-weight:800}.instr-subtitle{color:var(--text-muted);flex-wrap:wrap;align-items:center;gap:8px;margin-top:4px;font-size:13px;display:flex}.instr-type-badge{letter-spacing:.06em;text-transform:uppercase;border-radius:99px;padding:2px 7px;font-size:10px;font-weight:800}.instr-type-mosaic{color:#4a8064;background:#e8f2ec}.instr-type-c2c{background:var(--primary-light);color:var(--primary)}.close-btn{color:var(--text-muted);background:0 0;border:none;border-radius:4px;margin-left:16px;padding:0 4px;font-size:22px;line-height:1}.close-btn:hover{background:var(--border);color:var(--text)}.instr-controls{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:flex-end;gap:16px;padding:16px 24px;display:flex}.instr-corner-label{color:var(--text-muted);gap:5px;font-size:12px;font-weight:600}.corner-select{border:1.5px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);cursor:pointer;outline:none;padding:7px 10px;font-family:inherit;font-size:13px;display:block}.corner-select:focus{border-color:var(--primary)}.corner-select--full{width:100%}.btn-success{background:#16a34a!important}.instr-body{flex-direction:column;gap:20px;padding:20px 24px 28px;display:flex;overflow:auto}.instr-section-title{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:10px;font-size:11px;font-weight:700}.instr-color-key{flex-wrap:wrap;gap:8px;display:flex}.instr-color-row{background:var(--bg);border:1px solid var(--border);border-radius:6px;align-items:center;gap:8px;padding:6px 10px 6px 6px;font-size:13px;display:flex}.instr-code-badge{border:1px solid #0000001a;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:12px;font-weight:800;display:inline-flex}.instr-color-name{font-weight:600}.instr-color-hex{color:var(--text-muted);font-family:monospace;font-size:11px}.instr-notes{color:var(--text);flex-direction:column;gap:5px;font-size:13px;list-style:none;display:flex}.instr-notes li:before{content:"•";color:var(--primary);margin-right:6px;font-weight:700}.instr-foundation{background:var(--primary-light);color:var(--primary);border-radius:var(--radius);padding:10px 14px;font-size:14px;font-weight:500}.instr-rows{flex-direction:column;gap:2px;display:flex}.instr-row{border-radius:6px;flex-direction:column;gap:6px;padding:7px 10px;display:flex}.instr-row:nth-child(odd){background:var(--bg)}.instr-row-meta{align-items:center;gap:8px;display:flex}.instr-row-num{color:var(--primary);min-width:52px;font-size:12px;font-weight:700}.instr-row-dir{color:var(--text-muted);flex:1;font-size:11px;font-style:italic}.instr-row-blocks-count{color:var(--text-muted);margin-left:auto;margin-right:8px;font-size:11px}.instr-row-end{color:var(--text-muted);font-size:11px;font-style:italic}.instr-progress{background:var(--surface-tint);border-bottom:1px solid var(--border);flex-shrink:0;padding:14px 24px}.instr-progress-info{justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:8px;display:flex}.instr-progress-info strong{color:var(--text);font-size:13px}.instr-progress-info span{color:var(--text-muted);font-size:11px}.instr-progress-track{background:var(--border);border-radius:99px;height:6px;overflow:hidden}.instr-progress-fill{background:var(--primary);border-radius:99px;height:100%;transition:width .2s}.instr-progress-actions{align-items:center;gap:8px;margin-top:10px;display:flex}.instr-row--clickable{cursor:pointer}.instr-row--clickable:hover{box-shadow:inset 0 0 0 1.5px var(--border-mid)}.instr-row.instr-row--done{opacity:.45}.instr-row.instr-row--done .stitch-blocks{filter:grayscale(.35)}.instr-row.instr-row--current{background:var(--primary-light);box-shadow:inset 0 0 0 1.5px var(--primary)}.instr-check{border:1.5px solid var(--border-mid);background:var(--surface);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;font-size:11px;font-weight:700;display:inline-flex}.instr-check--done{background:var(--primary);border-color:var(--primary)}.phase-badge{border-radius:99px;flex-shrink:0;padding:2px 7px;font-size:10px;font-weight:700}.phase-increase{color:#15803d;background:#dcfce7}.phase-stable{background:var(--surface-tint);color:var(--text-muted)}.phase-decrease{color:#b91c1c;background:#fee2e2}.stitch-blocks{gap:1px;height:38px;display:flex}.stitch-block{cursor:default;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;transition:filter .1s;display:flex;overflow:hidden}.stitch-block:hover{filter:brightness(.9)}.stitch-block-count{letter-spacing:-.01em;font-size:12px;font-weight:800;line-height:1}.stitch-block-code{opacity:.75;margin-top:1px;font-size:9px;font-weight:700;line-height:1}.nav-link{color:var(--text-muted);font-size:14px;font-weight:400;text-decoration:none;transition:color .15s}.nav-link:hover{color:var(--text)}.btn-share--active{color:#15803d;border-radius:var(--radius);background:#dcfce7;border:1.5px solid #86efac;padding:6px 12px;font-size:13px;font-weight:600}.btn-share--active:hover{background:#bbf7d0}.view-only-badge{color:#92400e;background:#fef3c7;border:1px solid #fcd34d;border-radius:99px;padding:3px 10px;font-size:12px;font-weight:500}.pattern-name-row{align-items:center;gap:8px;margin-bottom:3px;display:flex}.shared-badge{color:#15803d;letter-spacing:.02em;background:#dcfce7;border:1px solid #86efac;border-radius:99px;flex-shrink:0;padding:1px 7px;font-size:10px;font-weight:700}.tag-chips{flex-wrap:wrap;gap:5px;min-height:0;margin-bottom:7px;display:flex}.tag-chip{color:var(--primary);background:var(--primary-light);border:1px solid #c4714b66;border-radius:99px;align-items:center;gap:4px;padding:2px 8px 2px 10px;font-size:12px;font-weight:500;line-height:1.4;display:inline-flex}.tag-chip--readonly{padding:2px 10px}.tag-chip-remove{color:var(--primary);cursor:pointer;opacity:.7;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;padding:0;font-size:14px;line-height:1;transition:opacity .1s,background .1s;display:flex}.tag-chip-remove:hover{opacity:1;background:#c4714b26}.tag-input{border:1.5px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);background:var(--surface);outline:none;padding:6px 10px;font-family:inherit;font-size:13px;transition:border-color .15s}.tag-input:focus{border-color:var(--primary)}.gallery-hero{color:#fff;background:linear-gradient(140deg,#5b21b6 0%,#7c3aed 60%,#6d28d9 100%);padding:52px 64px 60px}.gallery-hero-inner{max-width:860px;margin:0 auto}.gallery-hero-pill{letter-spacing:.06em;text-transform:uppercase;background:#ffffff26;border-radius:20px;align-items:center;gap:8px;margin-bottom:20px;padding:4px 14px 4px 10px;font-family:DM Sans,system-ui,sans-serif;font-size:12px;font-weight:500;display:inline-flex}.gallery-hero-dot{background:#fcd34d;border-radius:50%;flex-shrink:0;width:7px;height:7px;display:inline-block}.gallery-hero-title{letter-spacing:-.02em;max-width:560px;margin-bottom:12px;font-family:Lora,serif;font-size:40px;font-weight:700;line-height:1.1}.gallery-hero-sub{color:#fffc;max-width:480px;margin-bottom:24px;font-family:DM Sans,system-ui,sans-serif;font-size:15px;line-height:1.6}.gallery-hero-search-wrap{max-width:480px;position:relative}.gallery-hero-search-icon{pointer-events:none;position:absolute;top:50%;left:14px;transform:translateY(-50%)}input.gallery-hero-search{border-radius:var(--radius);color:#fff;box-sizing:border-box;background:#ffffff2e;border:none;outline:none;width:100%;padding:12px 16px 12px 40px;font-family:DM Sans,system-ui,sans-serif;font-size:14px;transition:background .15s,border-color .15s}.gallery-hero-search::placeholder{color:#fff9}.gallery-hero-search:focus{background:#ffffff40;box-shadow:0 0 0 1.5px #fff9}.gallery-tabs-bar{border-bottom:1px solid var(--border);background:#fff;gap:0;padding:0 64px;display:flex;overflow-x:auto}.gallery-tab{color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2.5px solid #0000;padding:14px 20px;font-family:DM Sans,system-ui,sans-serif;font-size:13px;font-weight:400;transition:color .12s,border-color .12s,background .12s}.gallery-tab:hover:not(.gallery-tab--active){background:var(--surface-tint);color:var(--text)}.gallery-tab--active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.gallery-grid-area{max-width:1160px;margin:0 auto;padding:28px 64px 80px}.gallery-toolbar{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.gallery-results-count{color:var(--text-muted);font-family:DM Sans,system-ui,sans-serif;font-size:14px}.gallery-sort-select{color:var(--text);background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;outline:none;padding:6px 10px;font-family:DM Sans,system-ui,sans-serif;font-size:13px}.gallery-sort-select:focus{border-color:var(--primary)}.gallery-card-header{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:3px;display:flex}.pattern-name-link{color:inherit;flex:1;text-decoration:none}.pattern-name-link:hover .pattern-name{color:var(--primary)}.gallery-card-header .pattern-name{flex:1;margin-bottom:0;transition:color .12s}.gallery-card-tags{flex-wrap:wrap;gap:4px;margin-top:6px;display:flex}.gallery-tag{color:var(--text-muted);background:var(--bg);border:1px solid var(--border);border-radius:99px;padding:2px 8px;font-size:11px;font-weight:500}.pd-breadcrumb{color:var(--text-subtle);align-items:center;gap:6px;padding:16px 60px;font-family:DM Sans,system-ui,sans-serif;font-size:13px;display:flex}.pd-breadcrumb-link{color:var(--primary);text-decoration:none}.pd-breadcrumb-link:hover{text-decoration:underline}.pd-breadcrumb-current{color:var(--text-muted)}.pd-content{grid-template-columns:1fr 320px;gap:32px;max-width:1160px;margin:0 auto;padding:0 60px 80px;display:grid}.pd-left{flex-direction:column;gap:24px;min-width:0;display:flex}.pd-right{flex-direction:column;gap:16px;display:flex}.pd-graph-card{border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow);background:#fff;overflow:hidden}.pd-graph-titlebar{background:var(--surface-tint);border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:12px 20px;display:flex}.pd-traffic-lights{gap:5px;display:flex}.pd-dot{border-radius:50%;width:10px;height:10px}.pd-filename{text-align:center;color:var(--text-subtle);flex:1;font-family:DM Sans,system-ui,sans-serif;font-size:12px}.pd-view-toggle{flex-shrink:0;gap:4px;display:flex}.pd-view-toggle-btn{color:var(--text-subtle);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:6px;padding:4px 10px;font:400 11px DM Sans,sans-serif}.pd-view-toggle-btn--active{background:var(--primary-light);color:var(--primary);border:none}.pd-graph-canvas{background:var(--bg);align-items:flex-start;padding:20px;display:flex;overflow:auto}.pd-graph-palette-strip{background:var(--surface-tint);border-top:1px solid var(--border);align-items:center;gap:8px;padding:10px 20px;display:flex}.pd-palette-label{color:var(--text-subtle);font-family:DM Sans,system-ui,sans-serif;font-size:11px}.pd-palette-swatches{gap:5px;display:flex}.pd-palette-swatch{border:1px solid #00000014;border-radius:4px;width:18px;height:18px}.pd-graph-footer-caption{color:var(--text-subtle);white-space:nowrap;margin-left:auto;font:400 11px DM Sans,sans-serif}.pd-rowguide{border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow);background:#fff;overflow:hidden}.pd-rowguide-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.pd-eyebrow{color:var(--primary);letter-spacing:.08em;text-transform:uppercase;font-family:DM Sans,system-ui,sans-serif;font-size:11px;font-weight:500}.pd-rowguide-note{color:var(--text-subtle);font-family:DM Sans,system-ui,sans-serif;font-size:11px}.pd-rowguide-rows{max-height:360px;padding:8px 0;overflow-y:auto}.pd-rg-row{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:6px 20px;display:flex}.pd-rg-row:last-child{border-bottom:none}.pd-rg-badge{background:var(--surface-tint);width:28px;height:28px;color:var(--primary);border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;font-family:DM Sans,system-ui,sans-serif;font-size:11px;font-weight:600;display:flex}.pd-rg-segs{flex-wrap:wrap;flex:1;gap:5px;min-width:0;display:flex}.pd-rg-seg{color:var(--text-muted);align-items:center;gap:3px;font-family:DM Sans,system-ui,sans-serif;font-size:11px;display:inline-flex}.pd-rg-swatch{border:1px solid #00000014;border-radius:2px;flex-shrink:0;width:10px;height:10px;display:inline-block}.pd-rg-count{font-weight:400}.pd-rg-colors{flex-shrink:0;gap:3px;display:flex}.pd-rg-mini{border:1px solid #00000014;border-radius:3px;width:12px;height:12px}.pd-title-card{border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow);background:#fff;padding:20px}.pd-tags{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.pd-tag{color:var(--text-muted);background:#f3f4f6;border-radius:99px;padding:3px 10px;font-family:DM Sans,system-ui,sans-serif;font-size:11px;font-weight:500}.pd-tag--primary{color:var(--primary);background:var(--primary-light)}.pd-title{color:var(--text);margin:0 0 16px;font-family:Lora,serif;font-size:26px;font-weight:700;line-height:1.2}.pd-author{align-items:center;gap:10px;display:flex}.pd-author-avatar{color:#fff;background:linear-gradient(135deg,#7c3aed,#a78bfa);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-family:DM Sans,system-ui,sans-serif;font-size:14px;font-weight:600;display:flex}.pd-author-name{color:var(--text);font-family:DM Sans,system-ui,sans-serif;font-size:13px;font-weight:500}.pd-author-date{color:var(--text-subtle);margin-top:2px;font-family:DM Sans,system-ui,sans-serif;font-size:12px}.pd-stats-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.pd-stat-cell{background:var(--bg);text-align:center;border:1px solid var(--border);border-radius:10px;padding:14px 8px}.pd-stat-num{color:var(--text);margin-bottom:5px;font-family:Lora,serif;font-size:20px;font-weight:700;line-height:1}.pd-stat-num--accent{color:var(--primary);font-size:22px}.pd-stat-label{color:var(--text-subtle);font-family:DM Sans,system-ui,sans-serif;font-size:11px}.pd-actions{flex-direction:column;gap:8px;display:flex}.pd-btn{width:100%;padding:12px 20px;font-family:DM Sans,system-ui,sans-serif;font-size:14px;font-weight:500}.pd-palette-card{border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow);background:#fff;padding:20px}.pd-palette-rows{flex-direction:column;gap:12px;display:flex}.pd-palette-row{align-items:center;gap:10px;display:flex}.pd-palette-row-swatch{border:1px solid #00000014;border-radius:5px;flex-shrink:0;width:22px;height:22px}.pd-palette-row-info{flex:1;min-width:0}.pd-palette-row-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-family:DM Sans,system-ui,sans-serif;font-size:11px;font-weight:500;overflow:hidden}.pd-palette-row-count{color:var(--text-subtle);margin-top:2px;font-family:DM Sans,system-ui,sans-serif;font-size:10px}.pd-palette-row-bar{background:var(--surface-tint);border-radius:3px;flex-shrink:0;width:56px;height:6px;overflow:hidden}.pd-palette-row-fill{border-radius:3px;min-width:2px;height:100%}@media (width<=900px){.pd-content{grid-template-columns:1fr;padding:0 24px 60px}.pd-right{order:-1}.pd-breadcrumb{padding:16px 24px}}@media (width<=640px){.gallery-hero{padding:36px 24px 44px}.gallery-hero-title{font-size:26px}.gallery-tabs-bar{padding:0 16px}.gallery-grid-area{padding:20px 16px 40px}.pd-breadcrumb{padding:14px 16px}.pd-content{padding:0 16px 40px}}.lp{background:var(--bg);min-height:100vh}.lp-nav{background:var(--bg);border-bottom:1px solid var(--border);z-index:100;align-items:center;padding:18px 60px;display:flex;position:sticky;top:0}.lp-logo{align-items:center;gap:9px;display:flex}.lp-wordmark{color:var(--text);font-family:Lora,serif;font-size:18px;font-weight:700;line-height:1}.lp-nav-links{align-items:center;gap:32px;margin:0 auto;display:flex}.lp-nav-link{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:0;padding:0;font-family:DM Sans,system-ui,sans-serif;font-size:14px;font-weight:400;transition:color .15s}.lp-nav-link:hover{color:var(--text);background:0 0}.lp-btn-nav{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:10px 22px;font-family:DM Sans,system-ui,sans-serif;font-size:14px;font-weight:500;transition:background .15s}.lp-btn-nav:hover{background:var(--primary-hover)}.lp-hero{align-items:center;gap:64px;max-width:1200px;margin:0 auto;padding:80px 60px 96px;display:flex;position:relative;overflow:hidden}.lp-grid-bg{pointer-events:none;background-image:linear-gradient(#7c3aed0d 1px,#0000 1px),linear-gradient(90deg,#7c3aed0d 1px,#0000 1px);background-size:24px 24px;position:absolute;inset:0}.lp-hero-left{z-index:1;flex:1;min-width:0;position:relative}.lp-beta-pill{background:var(--primary-light);color:var(--primary);border-radius:20px;align-items:center;gap:6px;margin-bottom:24px;padding:4px 14px 4px 7px;font-family:DM Sans,system-ui,sans-serif;font-size:12px;font-weight:500;display:inline-flex}.lp-beta-dot{background:var(--primary);border-radius:50%;flex-shrink:0;width:6px;height:6px;display:inline-block}.lp-headline{color:var(--text);margin-bottom:20px;font-family:Lora,serif;font-size:54px;font-weight:700;line-height:1.08}.lp-headline-em{color:var(--primary);font-style:italic}.lp-subtext{color:var(--text-muted);max-width:400px;margin-bottom:36px;font-family:DM Sans,system-ui,sans-serif;font-size:17px;font-weight:400;line-height:1.7}.lp-cta-row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.lp-btn-hero-primary{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:10px;padding:14px 28px;font-family:DM Sans,system-ui,sans-serif;font-size:15px;font-weight:500;transition:background .15s;box-shadow:0 4px 18px #7c3aed47}.lp-btn-hero-primary:hover{background:var(--primary-hover)}.lp-btn-hero-secondary{color:var(--text);cursor:pointer;background:0 0;border:1.5px solid #d1d5db;border-radius:10px;padding:14px 20px;font-family:DM Sans,system-ui,sans-serif;font-size:15px;font-weight:400;transition:border-color .15s}.lp-btn-hero-secondary:hover{border-color:#9ca3af}.lp-stats{border-top:1px solid var(--border);gap:32px;margin-top:40px;padding-top:28px;display:flex}.lp-stat-num{color:var(--text);font-family:Lora,serif;font-size:22px;font-weight:700;line-height:1}.lp-stat-label{color:var(--text-subtle);margin-top:4px;font-family:DM Sans,system-ui,sans-serif;font-size:12px;font-weight:300}.lp-hero-right{z-index:1;flex:0 0 360px;position:relative}.lp-mockup{border:1px solid var(--border);box-shadow:var(--shadow-lg);background:#fff;border-radius:16px;overflow:hidden}.lp-mockup-titlebar{background:var(--surface-tint);border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:10px 14px;display:flex}.lp-traffic-lights{gap:5px;display:flex}.lp-dot{border-radius:50%;width:9px;height:9px}.lp-filename{text-align:center;color:var(--text-subtle);flex:1;font-family:DM Sans,system-ui,sans-serif;font-size:11px}.lp-mockup-canvas{background:var(--bg);padding:18px}.lp-pattern-grid{background:#ddd6fe;border-radius:4px;grid-template-columns:repeat(10,26px);gap:2px;display:grid;overflow:hidden}.lp-pattern-cell{width:26px;height:26px}.lp-mockup-palette{background:var(--surface-tint);border-top:1px solid var(--border);align-items:center;gap:6px;padding:10px 14px;display:flex}.lp-palette-label{color:var(--text-subtle);font-family:DM Sans,system-ui,sans-serif;font-size:10px}.lp-palette-swatches{gap:5px;margin-left:8px;display:flex}.lp-swatch{border-radius:4px;width:18px;height:18px}.lp-swatch--bordered{border:1px solid #c4b5fd}.lp-export-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:6px;margin-left:auto;padding:5px 12px;font-family:DM Sans,system-ui,sans-serif;font-size:10px;font-weight:500}.lp-saved-chip{border:1px solid var(--border);background:#fff;border-radius:10px;align-items:center;gap:10px;width:fit-content;margin-top:10px;margin-left:auto;padding:9px 14px;display:flex;box-shadow:0 2px 12px #6d28d912}.lp-saved-icon{background:var(--primary-light);width:28px;height:28px;color:var(--primary);border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.lp-saved-title{color:var(--text);font-family:DM Sans,system-ui,sans-serif;font-size:11px;font-weight:600;line-height:1}.lp-saved-sub{color:var(--text-subtle);margin-top:4px;font-family:DM Sans,system-ui,sans-serif;font-size:10px;font-weight:300}.lp-how{border-top:1px solid var(--border);background:#fff;padding:80px 60px 96px}.lp-how-inner{max-width:1080px;margin:0 auto}.lp-how-header{text-align:center;margin-bottom:56px}.lp-eyebrow{color:var(--primary);letter-spacing:.1em;text-transform:uppercase;margin-bottom:12px;font-family:DM Sans,system-ui,sans-serif;font-size:12px;font-weight:500}.lp-how-headline{color:var(--text);font-family:Lora,serif;font-size:40px;font-weight:700;line-height:1.15}.lp-steps-wrapper{position:relative}.lp-steps-connector{background:repeating-linear-gradient(90deg,#d1d5db 0 7px,#0000 7px 16px);height:2px;position:absolute;top:36px;left:166px;right:166px}.lp-steps{grid-template-columns:repeat(3,1fr);gap:24px;display:grid}.lp-step{text-align:center;z-index:1;padding:0 24px;position:relative}.lp-step-circle{background:var(--primary-light);border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 20px;display:flex}.lp-step-circle--primary{border:3px solid var(--primary)}.lp-step-circle--mid{border:3px solid var(--primary-mid)}.lp-step-title{color:var(--text);margin-bottom:10px;font-family:Lora,serif;font-size:20px;font-weight:600;line-height:1.25}.lp-step-body{color:var(--text-muted);font-family:DM Sans,system-ui,sans-serif;font-size:14px;font-weight:400;line-height:1.7}.lp-cta-bar{background:var(--primary);justify-content:space-between;align-items:center;gap:24px;padding:56px 60px;display:flex}.lp-cta-headline{color:#fff;margin-bottom:8px;font-family:Lora,serif;font-size:26px;font-weight:700;line-height:1}.lp-cta-sub{color:#fffc;font-family:DM Sans,system-ui,sans-serif;font-size:15px}.lp-btn-cta{color:var(--primary);cursor:pointer;white-space:nowrap;background:#fff;border:none;border-radius:10px;flex-shrink:0;padding:14px 28px;font-family:DM Sans,system-ui,sans-serif;font-size:15px;font-weight:600;transition:transform .1s,box-shadow .15s}.lp-btn-cta:hover{transform:translateY(-1px);box-shadow:0 4px 16px #00000026}@media (width<=900px){.lp-hero{flex-direction:column;gap:48px;padding:48px 24px 64px}.lp-hero-right{flex:none;width:100%;max-width:380px;margin:0 auto}.lp-headline{font-size:40px}}@media (width<=640px){.lp-nav{padding:14px 20px}.lp-nav-links{display:none}.lp-hero{gap:40px;padding:40px 20px 56px}.lp-headline{font-size:34px}.lp-how{padding:56px 20px 72px}.lp-how-headline{font-size:28px}.lp-steps{grid-template-columns:1fr;gap:40px}.lp-steps-connector{display:none}.lp-cta-bar{flex-direction:column;align-items:flex-start;padding:40px 20px}}.sidebar-overlay{display:none}@media (width<=640px){.eh-panel-toggle{display:flex!important}.editor-header{gap:6px;padding:0 10px}.eh-logo,.eh-divider,.eh-nav-links,.eh-user,.unsaved-badge,.editor-left-toolbar{display:none}.editor-right-panel{z-index:30;width:85%;max-width:300px;box-shadow:var(--shadow-lg);transition:transform .22s;position:fixed;top:52px;bottom:28px;right:0;transform:translate(100%)}.editor-right-panel--open{transform:translate(0)}.sidebar-overlay{z-index:29;background:#00000059;display:block;position:fixed;inset:0}.canvas-pad{padding:16px}.canvas-zoom-badge{bottom:8px}.editor-statusbar{padding:0 10px;font-size:9px}.sb-sep{margin:0 8px}.dashboard-layout{flex-direction:column;overflow:hidden}.folder-sidebar{border-right:none;border-bottom:1px solid var(--border);scrollbar-width:none;flex-flow:row;flex-shrink:0;gap:6px;width:100%;height:auto;padding:8px 10px;overflow:auto hidden}.folder-sidebar::-webkit-scrollbar{display:none}.folder-sidebar-title{display:none}.folder-create-input{flex-shrink:0;width:auto;min-width:110px;margin-top:0}.folder-item{border:1.5px solid var(--border);white-space:nowrap;border-radius:99px;flex-shrink:0;width:auto;padding:5px 12px}.folder-item--active{border-color:var(--primary)}.folder-item-count,.folder-item-actions{display:none}.dashboard-main{flex:1;min-height:0;overflow-y:auto}.dashboard{padding:20px 16px}.dashboard-header{flex-direction:column;margin-bottom:20px}.patterns-grid{grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:12px}.gallery-hero{padding:32px 20px 40px}.gallery-tabs-bar{padding:0 20px}.gallery-grid-area{padding:20px 20px 40px}.navbar{padding:0 14px}.nav-user{display:none}.btn-primary,.btn-outline,.btn-danger{min-height:36px}.tool-btn{min-height:44px}.modal-overlay{align-items:flex-end;padding:0}.modal{border-bottom-right-radius:0;border-bottom-left-radius:0;max-height:90vh;padding:24px;overflow-y:auto}}
