.catalog-overlay{z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#37415166;position:fixed;inset:0}.catalog{background:var(--white);border:var(--border) solid var(--soft-black);border-radius:var(--radius-lg);width:min(920px,94vw);max-height:85vh;box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--lavender);z-index:201;flex-direction:column;display:flex;position:fixed;top:50%;left:50%;overflow:hidden;transform:translate(-50%,-50%)}.catalog-header{padding:20px 24px 12px;position:relative}.catalog-title{font-family:Fredoka,sans-serif;font-size:var(--font-lg);color:var(--soft-black);font-weight:700}.catalog-desc{font-size:var(--font-sm);color:var(--muted);margin-top:2px}.catalog-close{background:var(--bg);border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);cursor:pointer;width:32px;height:32px;box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);justify-content:center;align-items:center;padding:0;transition:transform .1s,box-shadow .1s;display:flex;position:absolute;top:16px;right:20px}.catalog-close:hover{box-shadow:calc(var(--shadow-x) + 2px) calc(var(--shadow-y) + 2px) 0 var(--shadow-color);transform:translate(-2px,-2px)}.catalog-close:active{box-shadow:none;transform:translate(0)}.catalog-close:before,.catalog-close:after{content:"";width:14px;height:var(--border);background:var(--soft-black);border-radius:1px;position:absolute}.catalog-close:before{transform:rotate(45deg)}.catalog-close:after{transform:rotate(-45deg)}.catalog-tabs{border-bottom:var(--border) solid var(--separator);gap:0;padding:0 24px;display:flex}.catalog-tab{font-family:Fredoka,sans-serif;font-size:var(--font-md);border:none;border-bottom:var(--border) solid transparent;color:var(--muted);cursor:pointer;margin-bottom:calc(var(--border) * -1);background:0 0;padding:12px 20px;font-weight:600;transition:all .15s}.catalog-tab:hover{color:var(--soft-black)}.catalog-tab.active{color:var(--soft-black);border-bottom-color:var(--lavender)}.catalog-body{flex:1;padding:16px 24px 24px;overflow-y:auto}.catalog-intensity{background:var(--bg);border:var(--border) solid var(--separator);border-radius:var(--radius-sm);align-items:center;gap:10px;margin-bottom:14px;padding:8px 12px;display:flex}.catalog-intensity-label{font-family:Fredoka,sans-serif;font-weight:600;font-size:var(--font-sm);white-space:nowrap}.catalog-intensity input[type=range]{flex:0 0 120px}.catalog-intensity-value{font-family:Fredoka,sans-serif;font-weight:700;font-size:var(--font-sm);background:var(--lavender);border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);text-align:center;min-width:28px;padding:2px 8px}.catalog-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;display:grid}.catalog-card{background:var(--bg);border:var(--border) solid var(--soft-black);border-radius:var(--radius-md);box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);padding:12px;transition:all .15s}.catalog-card:hover{box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color)}.catalog-card-header{align-items:center;gap:8px;margin-bottom:10px;display:flex}.catalog-card-icon{font-size:1.2rem}.catalog-card-name{font-family:Fredoka,sans-serif;font-size:var(--font-md);color:var(--soft-black);flex:1;font-weight:700;line-height:1.4}.catalog-card-name .effect-preview{font-size:calc(var(--font-md) + 2px);font-weight:700}.catalog-fav{cursor:pointer;color:var(--muted);border-radius:var(--radius-sm);background:0 0;border:none;padding:2px 4px;font-size:1.3rem;transition:all .15s}.catalog-fav:hover,.catalog-fav.is-fav{color:var(--peach)}.catalog-card-previews{flex-direction:column;gap:6px;margin-bottom:10px;display:flex}.catalog-preview-item{background:var(--white);color:var(--soft-black);border-radius:var(--radius-sm);border:var(--border) solid var(--separator);font-family:Segoe UI,Arial;font-size:var(--font-preview);white-space:nowrap;padding:8px 12px;line-height:1.5;overflow:hidden}.effect-preview{display:inline}.catalog-create-hint{font-family:Fredoka,sans-serif;font-weight:500;font-size:var(--font-md);color:var(--muted);margin-bottom:16px;line-height:1.5}.catalog-section{margin-bottom:16px}.catalog-section-header{border:none;border-bottom:var(--border) solid var(--separator);cursor:pointer;background:0 0;align-items:center;gap:8px;width:100%;margin-bottom:12px;padding:0 0 8px;transition:all .15s;display:flex}.catalog-section-header:hover .catalog-section-title{color:var(--lavender)}.catalog-section-arrow{font-size:var(--font-md);color:var(--muted);transition:transform .2s;display:inline-block}.catalog-section-arrow.open{transform:rotate(90deg)}.catalog-section-title{font-family:Fredoka,sans-serif;font-weight:700;font-size:var(--font-md);color:var(--soft-black)}.catalog-section-body{margin-bottom:8px}.catalog-card-sparkline{width:100%;height:28px;color:var(--lavender);margin-bottom:6px}.catalog-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:60px 24px;display:flex}.catalog-empty-icon{opacity:.4;font-size:48px}.catalog-empty-text{font-family:Fredoka,sans-serif;font-weight:700;font-size:var(--font-lg);color:var(--soft-black)}.catalog-empty-sub{font-family:Fredoka,sans-serif;font-weight:500;font-size:var(--font-md);color:var(--muted);line-height:1.5}.catalog-delete{border-radius:var(--radius-sm);background:var(--white);border:var(--border) solid var(--soft-black);cursor:pointer;width:26px;height:26px;box-shadow:2px 2px 0 var(--shadow-color);font-family:Fredoka,sans-serif;font-size:var(--font-xs);color:var(--soft-black);flex-shrink:0;justify-content:center;align-items:center;padding:0;font-weight:700;transition:all .1s;display:flex}.catalog-delete:hover{color:#ef4444;background:#fee2e2;border-color:#ef4444;transform:translate(-1px,-1px);box-shadow:3px 3px #fca5a5}.catalog-delete:active{box-shadow:none;transform:translate(0)}.catalog-card-expr{font-family:Fredoka,sans-serif;font-weight:600;font-size:var(--font-sm);color:var(--lavender);background:var(--white);border:var(--border) solid var(--separator);border-radius:var(--radius-sm);padding:4px 8px}.catalog-admin-id{font-family:Fredoka,sans-serif;font-size:var(--font-xs);color:var(--muted);background:var(--bg);border:1px dashed var(--separator);border-radius:var(--radius-sm);margin-top:4px;padding:2px 6px}.naming-overlay{z-index:300;border-radius:var(--radius-lg);background:#3741514d;position:absolute;inset:0}.naming-modal{background:var(--white);border:var(--border) solid var(--soft-black);border-radius:var(--radius-md);box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);z-index:301;flex-direction:column;gap:12px;min-width:320px;padding:20px 24px;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.naming-title{font-family:Fredoka,sans-serif;font-weight:700;font-size:var(--font-md);color:var(--soft-black)}.naming-input{font-family:Fredoka,sans-serif;font-size:var(--font-md);background:var(--white);color:var(--soft-black);border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);outline:none;padding:8px 14px;font-weight:600}.naming-input:focus{box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--lavender)}.naming-actions{gap:10px;display:flex}.color-creator{flex-direction:column;gap:14px;display:flex}.color-creator-label{font-family:Fredoka,sans-serif;font-weight:700;font-size:var(--font-sm);color:var(--soft-black);text-transform:uppercase;letter-spacing:.5px}.color-creator-palette{background:var(--bg);border:var(--border) solid var(--separator);border-radius:var(--radius-sm);flex-wrap:wrap;align-items:center;gap:8px;min-height:40px;padding:8px 10px;display:flex}.color-creator-swatch{border-radius:var(--radius-sm);border:var(--border) solid var(--soft-black);cursor:pointer;width:28px;height:28px;box-shadow:2px 2px 0 var(--shadow-color);transition:transform .1s}.color-creator-swatch:hover{transform:scale(1.15)}.color-creator-swatches{flex-wrap:wrap;gap:6px;display:flex}.color-creator-picker-wrap{flex-shrink:0;width:28px;height:28px;position:relative}.color-creator-picker-visual{border-radius:var(--radius-sm);border:var(--border) solid var(--soft-black);pointer-events:none;width:28px;height:28px}.color-creator-picker-wrap input[type=color]{opacity:0;cursor:pointer;width:100%;height:100%;position:absolute;inset:0}.color-creator-previews{flex-direction:column;gap:6px;display:flex}.color-creator-actions{gap:10px;display:flex}.emoji-picker-wrap{display:inline-block;position:relative}.emoji-picker-trigger{height:var(--btn-size);font-size:var(--font-sm);min-width:0;border-radius:var(--radius-sm)!important;padding:0 10px!important}.emoji-picker-trigger.has-value{font-size:1.2rem;padding:0 6px!important}.emoji-picker-backdrop{z-index:1000;position:fixed;inset:0}.emoji-picker{background:var(--white);border:var(--border) solid var(--soft-black);border-radius:var(--radius-md);box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);z-index:1001;width:380px;max-height:420px;padding:14px;overflow-y:auto}.emoji-picker-section{margin-bottom:10px}.emoji-picker-label{font-family:Fredoka,sans-serif;font-weight:700;font-size:var(--font-xs);color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.emoji-picker-grid{flex-wrap:wrap;gap:6px;display:flex}.emoji-picker-btn{border:var(--border) solid transparent;border-radius:var(--radius-sm);cursor:pointer;background:0 0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.4rem;transition:all .1s;display:flex}.emoji-picker-btn:hover{background:var(--bg);border-color:var(--separator)}.emoji-picker-btn.active{background:var(--lavender);border-color:var(--soft-black)}.emoji-picker-add-btn{font-family:Fredoka,sans-serif;font-weight:600;font-size:var(--font-sm);color:var(--lavender);cursor:pointer;background:0 0;border:none;padding:4px 0}.emoji-picker-add-btn:hover{color:var(--soft-black)}.emoji-picker-add-form{align-items:center;gap:6px;display:flex}.emoji-picker-add-input{border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);text-align:center;outline:none;width:80px;padding:4px 8px;font-size:1.4rem}.emoji-picker-hint{font-family:Fredoka,sans-serif;font-size:var(--font-xs);color:var(--muted);margin-top:4px;font-style:italic}.emoji-picker-item{display:inline-flex;position:relative}.emoji-picker-btn.is-fav{box-shadow:inset 0 -3px 0 var(--peach)}.emoji-picker-unfav{border-radius:var(--radius-sm);background:var(--white);border:var(--border) solid var(--soft-black);width:20px;height:20px;font-family:Fredoka,sans-serif;font-size:var(--font-xs);color:var(--soft-black);cursor:pointer;z-index:2;box-shadow:2px 2px 0 var(--shadow-color);justify-content:center;align-items:center;padding:0;font-weight:700;transition:all .1s;display:none;position:absolute;top:-8px;right:-8px}.emoji-picker-item:hover .emoji-picker-unfav{display:flex}.emoji-picker-unfav:hover{color:#ef4444;background:#fee2e2;border-color:#ef4444}.emoji-picker-fav-btn{border-radius:var(--radius-sm);background:var(--white);border:var(--border) solid var(--separator);width:20px;height:20px;font-family:Fredoka,sans-serif;font-size:var(--font-xs);color:var(--muted);cursor:pointer;z-index:2;box-shadow:2px 2px 0 var(--shadow-color);justify-content:center;align-items:center;padding:0;font-weight:700;line-height:1;transition:all .1s;display:none;position:absolute;top:-8px;left:-8px}.emoji-picker-item:hover .emoji-picker-fav-btn{display:flex}.emoji-picker-fav-btn:hover{border-color:var(--peach);color:var(--peach);background:color-mix(in srgb,var(--peach) 10%,var(--white))}.shape-canvas-container{flex-direction:column;gap:12px;display:flex}.shape-canvas{background:var(--bg);border-radius:var(--radius-md);cursor:crosshair;border:var(--border) solid var(--soft-black);width:100%;height:240px;box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);display:block}.shape-canvas-actions{gap:10px;display:flex}.math-container{flex-direction:column;gap:16px;display:flex}.math-formula{font-family:Fredoka,sans-serif;font-size:var(--font-lg);color:var(--soft-black);text-align:center;background:var(--bg);border:var(--border) solid var(--separator);border-radius:var(--radius-md);padding:10px 20px;font-weight:700}.math-formula-a,.math-formula-b,.math-formula-c{color:var(--lavender);font-size:22px}.math-formula-f{color:var(--peach);font-size:22px}.math-formula-paren,.math-formula-dot{color:var(--muted);font-weight:400}.math-text-preview{background:var(--white);border:var(--border) solid var(--soft-black);border-radius:var(--radius-md);box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);text-align:center;min-height:60px;font-family:Segoe UI,Arial;font-size:var(--font-preview);white-space:nowrap;padding:16px 24px;line-height:1.5;overflow:hidden}.math-input-row{align-items:center;gap:10px;display:flex}.math-input-prefix{font-family:Fredoka,sans-serif;font-weight:700;font-size:var(--font-md);color:var(--peach);white-space:nowrap}.math-input{font-family:Fredoka,sans-serif;font-size:var(--font-md);background:var(--white);color:var(--soft-black);border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);outline:none;flex:1;padding:8px 14px;font-weight:600}.math-input:focus{box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--lavender)}.math-btn-grid{flex-wrap:wrap;gap:8px;display:flex}.math-btn{font-family:Fredoka,sans-serif;font-weight:600;font-size:var(--font-sm);border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);cursor:pointer;-webkit-user-select:none;user-select:none;box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);padding:6px 14px;line-height:1;transition:transform .1s,box-shadow .1s}.math-btn:hover{box-shadow:calc(var(--shadow-x) + 2px) calc(var(--shadow-y) + 2px) 0 var(--shadow-color);transform:translate(-2px,-2px)}.math-btn:active{box-shadow:none;transform:translate(0)}.math-btn-func{background:var(--lavender);color:var(--soft-black)}.math-btn-op{background:var(--white);color:var(--soft-black)}.math-params{flex-direction:column;gap:10px;display:flex}.math-param{flex:1;align-items:center;gap:8px;display:flex}.math-param-name{font-family:Fredoka,sans-serif;font-weight:700;font-size:var(--font-lg);color:var(--lavender);text-align:center;min-width:18px}.math-param input[type=range]{flex:1;width:auto}.math-param-val{font-family:Fredoka,sans-serif;font-weight:700;font-size:var(--font-sm);background:var(--lavender);border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);text-align:center;min-width:36px;padding:2px 8px}.math-curve-canvas{background:var(--bg);border:var(--border) solid var(--soft-black);border-radius:var(--radius-md);width:100%;height:160px;box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);display:block}.btn{font-family:Fredoka,sans-serif;font-weight:600;font-size:var(--font-md);border:var(--border) solid var(--soft-black);border-radius:var(--radius-md);background:var(--white);color:var(--soft-black);-webkit-user-select:none;user-select:none;box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);padding:6px 16px;transition:transform .1s,box-shadow .1s}.btn:hover{box-shadow:calc(var(--shadow-x) + 2px) calc(var(--shadow-y) + 2px) 0 var(--shadow-color);transform:translate(-2px,-2px)}.btn:active,.btn.btn-pressed{box-shadow:none;transform:translate(0)}.btn-peach{background:var(--peach)}.btn-lavender{background:var(--lavender)}.btn-icon{font-family:Fredoka,sans-serif;font-weight:700;font-size:var(--font-md);width:var(--btn-size);height:var(--btn-size);border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);background:var(--white);color:var(--soft-black);-webkit-user-select:none;user-select:none;box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);justify-content:center;align-items:center;padding:0;transition:transform .1s,box-shadow .1s;display:inline-flex}.btn-icon:hover{box-shadow:calc(var(--shadow-x) + 2px) calc(var(--shadow-y) + 2px) 0 var(--shadow-color);transform:translate(-2px,-2px)}.btn-icon:active,.btn-icon.btn-pressed{box-shadow:none;transform:translate(0)}.btn-icon.active{background:var(--lavender)}.header{padding:var(--header-pad) 20px;border-bottom:var(--border) solid var(--soft-black);background:var(--bg);z-index:2;align-items:center;gap:12px;display:flex;position:relative}.header-logo{height:var(--header-logo-height);cursor:default;-webkit-user-select:none;user-select:none;pointer-events:none;width:auto;opacity:var(--header-logo-opacity);margin-top:var(--header-logo-margin-top);margin-right:var(--header-logo-margin-right)}.admin-gear{background:var(--peach);border:var(--border) solid var(--soft-black);cursor:pointer;z-index:200;width:40px;height:40px;box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--peach);-webkit-user-select:none;user-select:none;border-radius:50%;justify-content:center;align-items:center;font-size:20px;transition:transform .3s;display:flex;position:fixed;bottom:12px;right:16px}.admin-gear.open{transform:rotate(90deg)}.admin-gear:hover{transform:rotate(15deg)}.admin-tabs{border-bottom:var(--border) solid var(--separator);gap:0;padding:0 24px;display:flex}.admin-body{flex:1;padding:16px 24px 24px;overflow-y:auto}.admin-section{flex-direction:column;gap:10px;display:flex}.admin-section-label{font-family:Fredoka,sans-serif;font-weight:700;font-size:var(--font-sm);color:var(--soft-black);text-transform:uppercase;letter-spacing:.5px;border-bottom:var(--border) solid var(--separator);margin-top:16px;padding-bottom:6px}.admin-effect-row{background:var(--bg);border:var(--border) solid var(--separator);border-radius:var(--radius-sm);flex-wrap:wrap;align-items:center;gap:10px;padding:10px 12px;display:flex}.admin-effect-row.admin-custom{border-color:var(--peach)}.admin-effect-row.admin-effect-hidden{opacity:.35}.admin-effect-name{font-family:Fredoka,sans-serif;font-weight:700;font-size:var(--font-md);color:var(--soft-black);align-items:center;gap:6px;min-width:120px;display:flex}.admin-modified-badge,.admin-custom-badge{font-size:var(--font-xs);border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.5px;padding:1px 6px;font-weight:600}.admin-modified-badge{background:var(--lavender);color:var(--soft-black)}.admin-custom-badge{background:var(--peach);color:var(--soft-black)}.admin-bg-badge{background:var(--mint);color:var(--soft-black)}.admin-color-preview{flex-wrap:wrap;flex:1;gap:3px;display:flex}.admin-color-dot{border:2px solid var(--soft-black);cursor:pointer;border-radius:50%;flex-shrink:0;width:20px;height:20px;transition:transform .1s}.admin-color-dot:hover{transform:scale(1.2)}.admin-color-dot-edit{border-style:dashed}.admin-effect-actions{align-items:center;gap:6px;display:flex}.admin-btn{font-family:Fredoka,sans-serif;font-weight:600;font-size:var(--font-sm);border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);background:var(--white);color:var(--soft-black);cursor:pointer;padding:5px 14px;transition:transform .1s,box-shadow .1s}.admin-btn:hover{box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);transform:translate(-2px,-2px)}.admin-btn:active{box-shadow:none;transform:translate(0)}.admin-btn-danger{font-family:Fredoka,sans-serif;font-weight:600;font-size:var(--font-sm);border:var(--border) solid #ef4444;border-radius:var(--radius-sm);background:var(--white);color:#ef4444;cursor:pointer;padding:5px 14px;transition:all .1s}.admin-btn-danger:hover{background:#fee2e2;transform:translate(-2px,-2px);box-shadow:2px 2px #fca5a5}.admin-btn-danger:active{box-shadow:none;transform:translate(0)}.admin-edit-form{flex-direction:column;gap:8px;width:100%;padding:8px 0;display:flex}.admin-edit-colors{background:var(--white);border:var(--border) solid var(--separator);border-radius:var(--radius-sm);flex-wrap:wrap;align-items:center;gap:4px;min-height:28px;padding:6px;display:flex}.admin-add-color-wrap{width:24px;height:24px;position:relative}.admin-add-color-wrap input[type=color]{opacity:0;cursor:pointer;width:100%;height:100%;position:absolute;inset:0}.admin-add-color-wrap:before{content:"+";color:var(--muted);border:2px dashed var(--separator);pointer-events:none;border-radius:50%;justify-content:center;align-items:center;font-family:Fredoka,sans-serif;font-size:14px;font-weight:700;display:flex;position:absolute;inset:0}.admin-palette-quick{flex-wrap:wrap;gap:4px;display:flex}.admin-edit-row-top{align-items:center;gap:8px;display:flex}.admin-edit-actions{gap:8px;display:flex}.admin-add-effect-btn{font-family:Fredoka,sans-serif;font-weight:600;font-size:var(--font-sm);color:var(--lavender);border:var(--border) dashed var(--separator);border-radius:var(--radius-sm);cursor:pointer;text-align:left;background:0 0;width:100%;padding:10px 12px;transition:all .1s}.admin-add-effect-btn:hover{border-color:var(--lavender);color:var(--soft-black)}.admin-new-section{background:var(--white);border:var(--border) dashed var(--separator);border-radius:var(--radius-sm);margin-top:8px;padding:12px}.admin-emoji-list{grid-template-columns:repeat(3,1fr);gap:2px;display:grid}.admin-emoji-row{border-radius:var(--radius-sm);align-items:center;gap:6px;padding:5px 8px;transition:background .1s;display:flex}.admin-emoji-row:hover{background:var(--bg)}.admin-emoji-row.admin-emoji-hidden{opacity:.4}.admin-emoji-row.admin-emoji-hidden:hover{opacity:.7}.admin-emoji-char{text-align:center;flex-shrink:0;width:32px;font-size:1.4rem}.admin-emoji-label{font-family:Fredoka,sans-serif;font-weight:600;font-size:var(--font-sm);color:var(--soft-black);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.admin-emoji-actions{opacity:0;flex-shrink:0;gap:4px;transition:opacity .15s;display:flex}.admin-emoji-row:hover .admin-emoji-actions{opacity:1}.admin-emoji-action-btn{cursor:pointer;border-radius:var(--radius-sm);font-size:var(--font-sm);color:var(--muted);background:0 0;border:none;padding:4px 6px;transition:all .1s}.admin-emoji-action-btn:hover{background:var(--separator);color:var(--soft-black)}.admin-emoji-delete-btn:hover{color:#ef4444;background:#fee2e2}.admin-emoji-show-btn{opacity:.6}.admin-emoji-row:has(.admin-emoji-edit-form){grid-column:1/-1}.admin-emoji-edit-form{flex:1;align-items:center;gap:6px;display:flex}.admin-emoji-edit-form .naming-input{flex:1}.admin-emoji-add-row{align-items:center;gap:8px;margin-top:8px;display:flex}.admin-emoji-hint{font-family:Fredoka,sans-serif;font-size:var(--font-xs);color:var(--muted);margin-top:6px;font-style:italic}.admin-footer{border-top:var(--border) solid var(--separator);background:var(--bg);align-items:center;gap:12px;padding:14px 24px;display:flex}.admin-footer-hint{font-family:Fredoka,sans-serif;font-weight:500;font-size:var(--font-xs);color:var(--muted)}.admin-css-actions{flex-wrap:wrap;gap:6px;margin-bottom:14px;display:flex}.admin-sparkline{flex-shrink:0;width:80px;height:24px}.header-spacer{flex:1}.status-bar{background:var(--bg);border:var(--border) solid var(--separator);border-radius:var(--radius-md);cursor:default;-webkit-user-select:none;user-select:none;align-items:center;gap:6px;min-height:36px;padding:4px 10px;transition:border-color .2s,box-shadow .2s;display:flex}.status-bar-preview{border-color:var(--lavender);box-shadow:0 0 0 2px #c4b5fd66}.status-hint{font-family:Fredoka,sans-serif;font-weight:600;font-size:var(--font-xs);color:var(--muted);white-space:nowrap}.status-preview{border-radius:var(--radius-sm);border:var(--border) solid var(--separator);background:var(--white);-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;min-width:36px;min-height:28px;padding:2px 6px;line-height:1;transition:all .15s;display:inline-flex;overflow:hidden}.status-sep{background:var(--separator);flex-shrink:0;width:1px;height:20px}.status-info{font-family:Fredoka,sans-serif;font-weight:600;font-size:var(--font-sm);color:var(--soft-black);white-space:nowrap}.status-font{text-overflow:ellipsis;max-width:100px;overflow:hidden}.status-size{color:var(--muted)}.status-color-swatch{border:var(--border) solid var(--soft-black);pointer-events:none;border-radius:4px;flex-shrink:0;width:20px;height:20px}.status-fmt-ro{font-family:Fredoka,sans-serif;font-weight:700;font-size:var(--font-sm);width:22px;height:22px;color:var(--muted);-webkit-user-select:none;user-select:none;background:0 0;border-radius:4px;justify-content:center;align-items:center;padding:0;display:inline-flex}.status-fmt-ro.active{color:var(--soft-black);background:var(--lavender);border-radius:4px}.main-layout{z-index:1;flex:1;min-height:0;display:flex;position:relative}.side-panel{flex-direction:column;flex-shrink:0;gap:4px;padding:10px 6px;display:flex;overflow:hidden auto}.side-panel::-webkit-scrollbar{width:4px}.side-panel::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.side-panel-left{width:var(--side-width-left);border-right:var(--border) solid var(--separator);background:var(--white);padding:0;overflow:hidden}.side-dual-cols{flex:1;gap:0;height:100%;min-height:0;display:flex}.side-dual-cols .side-col{flex-direction:column;flex:1;gap:0;min-width:0;padding:0;display:flex}.side-dual-cols .side-col:first-child{border-right:1px solid var(--separator)}.side-col-scroll{flex-direction:column;flex:1;gap:4px;min-height:0;padding:4px 4px 10px;display:flex;overflow:hidden auto}.side-col-scroll::-webkit-scrollbar{width:3px}.side-col-scroll::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.side-panel-right{width:var(--side-width-right);border-left:var(--border) solid var(--separator);background:var(--white)}.side-panel-title{font-family:Fredoka,sans-serif;font-weight:700;font-size:var(--font-xs);text-transform:uppercase;letter-spacing:1.5px;color:var(--muted);text-align:center;border-bottom:var(--border) solid var(--separator);margin-bottom:2px;padding:4px 0 6px}.side-label{font-family:Fredoka,sans-serif;font-weight:700;font-size:var(--font-xs);text-transform:uppercase;letter-spacing:1px;color:var(--muted);padding:6px 4px 2px}.side-sep{background:var(--separator);height:1px;margin:4px}.side-tag{font-family:Fredoka,sans-serif;font-weight:600;font-size:var(--font-sm);border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);background:var(--white);color:var(--soft-black);box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);-webkit-user-select:none;user-select:none;text-align:center;white-space:nowrap;cursor:pointer;justify-content:center;align-items:center;width:100%;min-height:32px;padding:4px 6px;line-height:1;transition:transform .1s,box-shadow .1s;display:flex;overflow:hidden}.side-tag span{line-height:1}.side-tag:hover{box-shadow:calc(var(--shadow-x) + 2px) calc(var(--shadow-y) + 2px) 0 var(--shadow-color);transform:translate(-2px,-2px)}.side-tag:active,.side-tag.btn-pressed{box-shadow:none;transform:translate(0)}.side-tag.active{background:var(--lavender)}.side-tag.armed{border-left:5px solid var(--peach);background:#fdba740f}.side-tag.recent{opacity:.7;border-style:dashed}.side-tag-wrap{width:100%;position:relative}.side-tag-x{border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);background:var(--white);width:20px;height:20px;color:var(--muted);cursor:pointer;z-index:3;box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);justify-content:center;align-items:center;padding:0;font-family:Fredoka,sans-serif;font-size:10px;font-weight:700;line-height:1;transition:transform .1s,box-shadow .1s,color .1s,background .1s;display:flex;position:absolute;top:-6px;right:-6px}.side-tag-x:hover{color:#ef4444;box-shadow:calc(var(--shadow-x) + 1px) calc(var(--shadow-y) + 1px) 0 var(--shadow-color);background:#fee2e2;transform:translate(-1px,-1px)}.side-tag-x:active{box-shadow:none;transform:translate(0)}.side-tag-star{border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);background:var(--white);width:20px;height:20px;color:var(--muted);cursor:pointer;z-index:3;box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);justify-content:center;align-items:center;padding:0;font-family:Fredoka,sans-serif;font-size:10px;font-weight:700;line-height:1;transition:transform .1s,box-shadow .1s,color .1s,background .1s;display:flex;position:absolute;bottom:-6px;right:-6px}.side-tag-star:hover{color:var(--peach);background:var(--bg);box-shadow:calc(var(--shadow-x) + 1px) calc(var(--shadow-y) + 1px) 0 var(--shadow-color);transform:translate(-1px,-1px)}.side-tag-star:active{box-shadow:none;transform:translate(0)}.side-tag-size{white-space:normal;flex-direction:column;align-items:stretch;gap:2px;min-height:42px;padding:4px 8px}.side-tag-name{font-family:Fredoka,sans-serif;font-weight:700;font-size:var(--font-xs);text-align:center;color:var(--soft-black);line-height:1.2}.side-tag-sparkline{width:100%;height:18px}.center-area{flex-direction:column;flex:1;min-width:0;min-height:0;display:flex}.toolbar-panel{border:var(--border) solid var(--soft-black);background:var(--white);border-top:none;flex-direction:column;gap:4px;padding:4px 0;display:flex;overflow:hidden}.toolbar-row{padding:var(--toolbar-pad) 16px;flex-wrap:wrap;align-items:center;gap:8px;display:flex}.separator{width:var(--border);background:var(--separator);flex-shrink:0;height:28px;margin:0 2px}.swatches{flex-wrap:wrap;align-items:center;gap:5px;display:flex}.swatch-wrap{display:inline-flex;position:relative}.swatch{width:var(--swatch-size);height:var(--swatch-size);border:var(--border) solid var(--soft-black);cursor:pointer;border-radius:50%;transition:transform .1s,box-shadow .1s}.swatch:hover{box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);transform:translate(-2px,-2px)}.swatch:active{box-shadow:none;transform:translate(0)}.swatch-active{box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);transform:translate(-2px,-2px)}.swatch-remove{border-radius:var(--radius-sm);background:var(--white);border:var(--border) solid var(--soft-black);cursor:pointer;z-index:2;width:20px;height:20px;box-shadow:2px 2px 0 var(--shadow-color);font-family:Fredoka,sans-serif;font-size:var(--font-xs);color:var(--soft-black);justify-content:center;align-items:center;padding:0;font-weight:700;transition:all .1s;display:flex;position:absolute;top:-8px;right:-8px}.swatch-remove:hover{color:#ef4444;background:#fee2e2;border-color:#ef4444;transform:translate(-1px,-1px);box-shadow:3px 3px #fca5a5}.swatch-remove:active{box-shadow:none;transform:translate(0)}.toggle-group{border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);display:flex;overflow:hidden}.toggle-btn{font-family:Fredoka,sans-serif;font-weight:600;font-size:var(--font-sm);background:var(--white);color:var(--soft-black);border:none;padding:4px 12px;transition:background .1s}.toggle-btn.active{background:var(--lavender)}.toggle-btn:first-child{border-right:var(--border) solid var(--soft-black)}.color-picker-wrapper{width:var(--swatch-size);height:var(--swatch-size);position:relative}.color-picker-visual{width:var(--swatch-size);height:var(--swatch-size);border:var(--border) solid var(--soft-black);pointer-events:none;background:conic-gradient(red,#ff0,#0f0,#0ff,#00f,#f0f,red);border-radius:50%;transition:transform .1s}.color-picker-wrapper:hover .color-picker-visual{box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);transform:translate(-2px,-2px)}.color-picker-wrapper input[type=color]{opacity:0;cursor:pointer;width:100%;height:100%;position:absolute;top:0;left:0}.font-select{font-weight:600;font-size:var(--font-sm);border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);background:var(--white);color:var(--soft-black);cursor:pointer;padding:4px 10px}.slider-group{align-items:center;gap:6px;display:flex}.slider-label{font-family:Fredoka,sans-serif;font-weight:600;font-size:var(--font-sm);white-space:nowrap}input[type=range]{appearance:none;cursor:pointer;background:0 0;border:none;outline:none;width:90px;height:24px;margin:0;padding:0}input[type=range]::-webkit-slider-runnable-track{background:var(--separator);border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);height:8px}input[type=range]::-webkit-slider-thumb{appearance:none;background:var(--lavender);border:var(--border) solid var(--soft-black);cursor:pointer;border-radius:50%;width:18px;height:18px;margin-top:-8px}input[type=range]::-moz-range-track{background:var(--separator);border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);height:8px}input[type=range]::-moz-range-thumb{background:var(--lavender);border:var(--border) solid var(--soft-black);cursor:pointer;border-radius:50%;width:18px;height:18px}.slider-value{font-family:Fredoka,sans-serif;font-weight:700;font-size:var(--font-sm);background:var(--lavender);border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);text-align:center;box-sizing:border-box;justify-content:center;align-items:center;min-width:32px;height:28px;padding:2px 8px;display:inline-flex}.slider-value-clickable{cursor:pointer;transition:transform .1s,box-shadow .1s}.slider-value-clickable:hover{box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);transform:translate(-2px,-2px)}.slider-value-clickable:active{box-shadow:none;transform:translate(0)}.slider-value-input{font-family:Fredoka,sans-serif;font-weight:700;font-size:var(--font-sm);border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);text-align:center;background:var(--white);box-sizing:border-box;-moz-appearance:textfield;outline:none;width:48px;height:28px;padding:2px 4px}.slider-value-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.slider-value-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.slider-value-input:focus{border-color:var(--lavender);box-shadow:0 0 0 2px #c4b5fd66}.size-control-wrap{align-items:center;display:inline-flex;position:relative}.size-value-row{align-items:center;gap:0;display:flex}.size-value-row .slider-value{border-radius:var(--radius-sm) 0 0 var(--radius-sm);border-right:none}.size-dropdown-arrow{border:var(--border) solid var(--soft-black);border-radius:0 var(--radius-sm) var(--radius-sm) 0;background:var(--lavender);width:20px;height:28px;color:var(--soft-black);cursor:pointer;box-sizing:border-box;justify-content:center;align-items:center;padding:0;font-family:Fredoka,sans-serif;font-size:10px;transition:transform .1s,box-shadow .1s;display:inline-flex}.size-dropdown-arrow:hover{background:var(--peach)}.size-dropdown-backdrop{z-index:1000;position:fixed;inset:0}.size-dropdown{background:var(--white);border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);min-width:64px;max-height:300px;box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--lavender);z-index:1001;padding:2px;position:fixed;overflow-y:auto}.size-dropdown::-webkit-scrollbar{width:4px}.size-dropdown::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.size-dropdown-item{cursor:pointer;width:100%;font-family:Fredoka,sans-serif;font-weight:600;font-size:var(--font-sm);color:var(--soft-black);text-align:left;background:0 0;border:none;border-radius:4px;padding:4px 10px;transition:background .1s;display:block}.size-dropdown-item:hover{background:var(--bg)}.size-dropdown-item.active{background:var(--lavender);font-weight:700}.tb-pills{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.tb-pill-wrap{display:inline-flex;position:relative}.tb-pill{font-family:Fredoka,sans-serif;font-weight:600;font-size:var(--font-sm);border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);background:var(--bg);color:var(--soft-black);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;text-overflow:ellipsis;max-width:90px;padding:2px 8px;transition:transform .1s,box-shadow .1s;overflow:hidden}.tb-pill:hover{box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);transform:translate(-1px,-1px)}.tb-pill:active{box-shadow:none;transform:translate(0)}.tb-pill.tb-recent{opacity:.65;border-style:dashed}.tb-pill.tb-emoji{text-align:center;min-width:28px;max-width:none;padding:2px 4px;font-size:1.1rem;overflow:visible}.tb-pill-x{border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);background:var(--white);width:20px;height:20px;color:var(--muted);cursor:pointer;z-index:2;box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);justify-content:center;align-items:center;padding:0;font-family:Fredoka,sans-serif;font-size:10px;font-weight:700;line-height:1;transition:transform .1s,box-shadow .1s,color .1s,background .1s;display:flex;position:absolute;top:-8px;right:-8px}.tb-pill-x:hover{color:#ef4444;box-shadow:calc(var(--shadow-x) + 1px) calc(var(--shadow-y) + 1px) 0 var(--shadow-color);background:#fee2e2;transform:translate(-1px,-1px)}.tb-pill-x:active{box-shadow:none;transform:translate(0)}.tb-pill-star{border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);background:var(--white);width:20px;height:20px;color:var(--muted);cursor:pointer;z-index:2;box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);justify-content:center;align-items:center;padding:0;font-family:Fredoka,sans-serif;font-size:10px;font-weight:700;line-height:1;transition:transform .1s,box-shadow .1s,color .1s,background .1s;display:flex;position:absolute;bottom:-8px;right:-8px}.tb-pill-star:hover{color:var(--peach);background:var(--bg);box-shadow:calc(var(--shadow-x) + 1px) calc(var(--shadow-y) + 1px) 0 var(--shadow-color);transform:translate(-1px,-1px)}.tb-pill-star:active{box-shadow:none;transform:translate(0)}.link-indicator{font-family:Fredoka,sans-serif;font-weight:600;font-size:var(--font-sm);background:var(--mint);border:var(--border) solid var(--soft-black);border-radius:var(--radius-md);color:var(--soft-black);cursor:pointer;white-space:nowrap;text-overflow:ellipsis;max-width:220px;box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);padding:4px 12px;transition:transform .1s,box-shadow .1s;overflow:hidden}.link-indicator:hover{box-shadow:calc(var(--shadow-x) + 2px) calc(var(--shadow-y) + 2px) 0 var(--shadow-color);transform:translate(-2px,-2px)}.link-indicator:active{box-shadow:none;transform:translate(0)}.link-indicator-edit{align-items:center;gap:6px;display:flex}.link-indicator-input{font-family:Fredoka,sans-serif;font-size:var(--font-sm);border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);background:var(--white);color:var(--soft-black);width:200px;box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);outline:none;padding:4px 10px;font-weight:600}.link-indicator-input:focus{border-color:var(--lavender);box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--lavender)}.link-indicator-btn{font-size:var(--font-sm)!important;padding:4px 10px!important}.link-indicator-del{color:#ef4444;background:var(--white)!important;border-color:#ef4444!important}.link-indicator-del:hover{background:#ef444414!important}.history-backdrop{z-index:1000;position:fixed;inset:0}.history-panel{background:var(--white);border:var(--border) solid var(--soft-black);border-radius:var(--radius-md);width:260px;max-height:400px;box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--lavender);z-index:1001;flex-direction:column;animation:.12s historyIn;display:flex;position:fixed;overflow:hidden}@keyframes historyIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.history-header{font-family:Fredoka,sans-serif;font-weight:700;font-size:var(--font-md);color:var(--soft-black);border-bottom:var(--border) solid var(--separator);padding:10px 14px}.history-list{flex:1;padding:4px;overflow-y:auto}.history-list::-webkit-scrollbar{width:4px}.history-list::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.history-entry{cursor:pointer;border-radius:var(--radius-sm);text-align:left;background:0 0;border:none;align-items:center;gap:8px;width:100%;padding:6px 10px;font-family:Fredoka,sans-serif;transition:background .1s;display:flex}.history-entry:hover{background:var(--bg)}.history-entry-current{cursor:default;font-weight:700;background:var(--lavender)!important}.history-entry-icon{font-size:var(--font-sm);text-align:center;width:18px;color:var(--muted);flex-shrink:0}.history-entry-current .history-entry-icon{color:var(--soft-black)}.history-entry-label{font-size:var(--font-sm);color:var(--soft-black);text-overflow:ellipsis;white-space:nowrap;flex:1;font-weight:600;overflow:hidden}.history-entry-time{font-size:var(--font-xs);color:var(--muted);white-space:nowrap}.editor-wrapper{flex:1;min-height:0;position:relative}.editor-logo{width:var(--logo-size);height:var(--logo-size);object-fit:contain;pointer-events:none;filter:grayscale();opacity:var(--logo-opacity);z-index:1;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.editor-viewport{border:var(--border) solid var(--soft-black);background:var(--white);border-top:none;position:absolute;inset:0;overflow:hidden}.editor-viewport:before,.editor-viewport:after{content:"";background:var(--separator);z-index:5;pointer-events:none;width:1px;position:absolute;top:0;bottom:0}.editor-viewport:before{left:var(--sep-left-1)}.editor-viewport:after{left:var(--sep-left-2)}.editor{background:var(--white);height:100%;font-size:var(--font-editor);color:var(--soft-black);column-fill:auto;box-sizing:border-box;overflow-wrap:break-word;word-break:break-word;outline:none;column-gap:24px;padding:20px;line-height:1.8;transition:transform .3s;position:relative;overflow:hidden}.page-nav{z-index:6;-webkit-user-select:none;user-select:none;align-items:center;gap:4px;display:flex;position:absolute;bottom:8px;right:10px}.page-nav-label{font-family:Fredoka,sans-serif;font-weight:600;font-size:var(--font-xs);color:var(--muted);pointer-events:none}.page-nav-btn{border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);background:var(--white);width:22px;height:22px;color:var(--soft-black);cursor:pointer;box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);justify-content:center;align-items:center;padding:0;font-family:Fredoka,sans-serif;font-size:14px;transition:transform .1s,box-shadow .1s;display:inline-flex}.page-nav-btn:hover{box-shadow:calc(var(--shadow-x) + 2px) calc(var(--shadow-y) + 2px) 0 var(--shadow-color);transform:translate(-2px,-2px)}.page-nav-btn:active{box-shadow:none;transform:translate(0)}.editor:focus,.editor:focus-visible{outline:none}.editor:empty:before{content:"Ecrivez ici...";color:var(--muted);pointer-events:none;font-style:italic}.editor span[style*=background]{vertical-align:text-bottom;line-height:1.15;display:inline-block}.layout-switcher{z-index:6;-webkit-user-select:none;user-select:none;gap:3px;display:flex;position:absolute;top:6px;right:10px}.layout-btn{border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);background:var(--white);width:26px;height:22px;color:var(--muted);cursor:pointer;box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);justify-content:center;align-items:center;padding:0;transition:transform .1s,box-shadow .1s,color .15s,background .15s;display:inline-flex}.layout-btn:hover{box-shadow:calc(var(--shadow-x) + 1px) calc(var(--shadow-y) + 1px) 0 var(--shadow-color);color:var(--soft-black);transform:translate(-1px,-1px)}.layout-btn:active{box-shadow:none;transform:translate(0)}.layout-btn-active{background:var(--soft-black);color:var(--white);box-shadow:none}.layout-btn-active:hover{box-shadow:none;color:var(--white);transform:none}.editor a{border-bottom:1.5px dashed var(--mint);transition:border-color .2s}.editor a:hover{border-bottom-color:var(--peach)}.line-break{opacity:.5;pointer-events:none;-webkit-user-select:none;user-select:none;margin-left:2px;font-family:Fredoka,sans-serif;font-weight:700;color:var(--lavender)!important;vertical-align:baseline!important;background:0 0!important;font-size:14px!important;line-height:normal!important;display:inline!important}.toast{background:var(--white);border:var(--border) solid var(--soft-black);color:var(--soft-black);font-family:Fredoka,sans-serif;font-weight:600;font-size:var(--font-md);border-radius:var(--radius-md);box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--mint);opacity:0;pointer-events:none;z-index:1000;padding:10px 24px;transition:all .2s;position:fixed;bottom:20px;left:50%;transform:translate(-50%)translateY(60px)}.toast.visible{opacity:1;transform:translate(-50%)translateY(0)}.toast.error{box-shadow:var(--shadow-x) var(--shadow-y) 0 #fca5a5;border-color:#ef4444}.tweaker-gear{background:var(--lavender);border:var(--border) solid var(--soft-black);cursor:pointer;z-index:200;width:40px;height:40px;box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--lavender);-webkit-user-select:none;user-select:none;border-radius:50%;justify-content:center;align-items:center;font-size:20px;transition:transform .3s;display:flex;position:fixed;bottom:12px;right:16px}.tweaker-gear.open{transform:rotate(90deg)}.tweaker-panel{background:var(--white);border:var(--border) solid var(--soft-black);border-radius:var(--radius-md);max-height:70vh;box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);z-index:150;opacity:0;pointer-events:none;flex-direction:column;padding:14px 18px;transition:all .2s;display:flex;position:fixed;bottom:52px;left:16px;right:16px;overflow:hidden;transform:scale(.95)translateY(10px)}.tweaker-panel.open{opacity:1;pointer-events:auto;transform:scale(1)translateY(0)}.tweaker-header{flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:6px;margin-bottom:10px;display:flex}.tweaker-title{font-family:Fredoka,sans-serif;font-weight:700;font-size:var(--font-md)}.tweaker-categories{flex-direction:column;flex:1;gap:14px;min-height:0;padding-right:4px;display:flex;overflow-y:auto}.tweaker-categories::-webkit-scrollbar{width:4px}.tweaker-categories::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.tweaker-category-toggle{border:none;border-bottom:var(--border) solid var(--separator);cursor:pointer;background:0 0;align-items:center;gap:6px;width:100%;margin-bottom:6px;padding:0 0 4px;transition:all .15s;display:flex}.tweaker-category-toggle:hover{color:var(--lavender)}.tweaker-arrow{font-size:var(--font-sm);color:var(--muted);transition:transform .2s;display:inline-block}.tweaker-arrow.open{transform:rotate(90deg)}.tweaker-category-title{font-family:Fredoka,sans-serif;font-weight:700;font-size:var(--font-sm);color:var(--soft-black)}.tweaker-category-grid{grid-template-columns:repeat(4,1fr);gap:8px 16px;display:grid}.tweaker-control{flex-direction:column;gap:2px;display:flex}.tweaker-control label{font-family:Fredoka,sans-serif;font-weight:600;font-size:var(--font-xs);color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.tweak-row{align-items:center;gap:6px;display:flex}.tweak-row input[type=range]{flex:1;width:auto}.tweak-val{font-family:Fredoka,sans-serif;font-weight:700;font-size:var(--font-sm);background:var(--lavender);border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);text-align:center;min-width:36px;padding:1px 6px}.tweak-val-color{font-size:var(--font-xs);min-width:60px}.tweak-color-wrapper{flex-shrink:0;width:22px;height:22px;position:relative}.tweak-color-swatch{border-radius:var(--radius-sm);border:var(--border) solid var(--soft-black);pointer-events:none;width:22px;height:22px}.tweak-color-wrapper input[type=color]{opacity:0;cursor:pointer;width:100%;height:100%;position:absolute;inset:0}@keyframes slideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.side-tag-enter{animation:.3s both slideIn}.side-tag-placeholder{visibility:hidden;width:100%;min-height:32px}.btn-compact{font-family:Fredoka,sans-serif;font-weight:600;font-size:var(--font-sm);border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);background:var(--white);color:var(--soft-black);-webkit-user-select:none;user-select:none;box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);padding:3px 10px;transition:transform .1s,box-shadow .1s}.btn-compact:hover{box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);transform:translate(-2px,-2px)}.btn-compact:active,.btn-compact.btn-pressed{box-shadow:none;transform:translate(0)}.fav-add{font-family:Fredoka,sans-serif;font-weight:700;font-size:var(--font-sm);border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);background:var(--white);width:24px;height:24px;color:var(--soft-black);cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;padding:0;transition:transform .1s,box-shadow .1s;display:inline-flex}.fav-add:hover{box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);transform:translate(-2px,-2px)}.fav-add:active{box-shadow:none;transform:translate(0)}.font-picker{z-index:60;align-items:center;gap:4px;display:flex;position:relative}.font-picker-trigger{font-weight:600;font-size:var(--font-sm);border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);background:var(--white);color:var(--soft-black);cursor:pointer;min-width:100px;box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);align-items:center;gap:6px;padding:4px 10px;transition:transform .1s,box-shadow .1s;display:flex}.font-picker-trigger:hover{box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);transform:translate(-2px,-2px)}.font-picker-trigger:active{box-shadow:none;transform:translate(0)}.font-picker-arrow{color:var(--muted);font-size:8px}.font-picker-backdrop{z-index:1000;position:fixed;inset:0}.font-picker-menu{background:var(--white);border:var(--border) solid var(--soft-black);border-radius:var(--radius-md);width:300px;max-height:400px;box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--lavender);z-index:1001;padding:6px;position:fixed;overflow-y:auto}.font-picker-menu::-webkit-scrollbar{width:4px}.font-picker-menu::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.font-picker-category{font-family:Fredoka,sans-serif;font-weight:700;font-size:var(--font-xs);text-transform:uppercase;letter-spacing:1px;color:var(--muted);padding:10px 10px 4px}.font-picker-item{cursor:pointer;border-radius:var(--radius-sm);text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:8px 10px;transition:background .1s;display:flex}.font-picker-item:hover{background:var(--bg)}.font-picker-item.selected{background:var(--lavender)}.font-picker-item-preview{text-align:center;width:36px;color:var(--soft-black);flex-shrink:0;font-size:20px;line-height:1}.font-picker-item-name{font-family:Fredoka,sans-serif;font-size:var(--font-md);color:var(--soft-black);flex:1;font-weight:600}.palette-btn{border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);background:var(--white);cursor:pointer;height:var(--btn-size);align-items:center;gap:4px;padding:4px 8px;transition:transform .1s,box-shadow .1s;display:flex}.palette-btn:hover{box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);transform:translate(-2px,-2px)}.palette-btn:active{box-shadow:none;transform:translate(0)}.palette-btn-icon{border:2px solid var(--soft-black);background:conic-gradient(red,#ff0,#0f0,#0ff,#00f,#f0f,red);border-radius:50%;flex-shrink:0;width:18px;height:18px}.palette-btn-name{font-family:Fredoka,sans-serif;font-weight:600;font-size:var(--font-xs);color:var(--soft-black);text-overflow:ellipsis;white-space:nowrap;max-width:60px;overflow:hidden}.palette-mgr-backdrop{z-index:200;position:fixed;inset:0}.palette-mgr{z-index:201;background:var(--white);border:var(--border) solid var(--soft-black);border-radius:var(--radius-md);box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);min-width:300px;max-width:380px;max-height:420px;padding:12px;position:fixed;overflow-y:auto}.palette-mgr-header{font-family:Fredoka,sans-serif;font-weight:700;font-size:var(--font-md);color:var(--soft-black);align-items:center;gap:8px;margin-bottom:10px;display:flex}.palette-mgr-back{font-size:var(--font-md);cursor:pointer;color:var(--muted);background:0 0;border:none;padding:0 4px}.palette-mgr-back:hover{color:var(--soft-black)}.palette-mgr-item{border-radius:var(--radius-sm);cursor:pointer;border:2px solid #0000;align-items:center;gap:8px;padding:8px 10px;transition:background .1s;display:flex}.palette-mgr-item:hover{background:var(--bg)}.palette-mgr-item.active{border-color:var(--lavender);background:color-mix(in srgb,var(--lavender) 15%,transparent)}.palette-mgr-item-colors{flex-shrink:0;gap:3px;display:flex}.palette-mgr-dot{border:2px solid var(--soft-black);border-radius:50%;width:14px;height:14px}.palette-mgr-more{font-family:Fredoka,sans-serif;font-weight:600;font-size:var(--font-xs);color:var(--muted)}.palette-mgr-empty{font-family:Fredoka,sans-serif;font-weight:500;font-size:var(--font-xs);color:var(--muted);font-style:italic}.palette-mgr-item-name{font-family:Fredoka,sans-serif;font-weight:600;font-size:var(--font-sm);color:var(--soft-black);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.palette-mgr-item-actions{opacity:0;flex-shrink:0;gap:2px;transition:opacity .15s;display:flex}.palette-mgr-item:hover .palette-mgr-item-actions{opacity:1}.palette-mgr-action{cursor:pointer;border-radius:var(--radius-sm);font-size:var(--font-xs);color:var(--muted);background:0 0;border:none;padding:3px 5px;transition:all .1s}.palette-mgr-action:hover{background:var(--separator);color:var(--soft-black)}.palette-mgr-delete:hover{color:#ef4444;background:#fee2e2}.palette-mgr-rename-input{font-family:Fredoka,sans-serif;font-weight:600;font-size:var(--font-sm);border:var(--border) solid var(--lavender);border-radius:var(--radius-sm);outline:none;flex:1;min-width:0;padding:2px 6px}.palette-mgr-new-btn{font-family:Fredoka,sans-serif;font-weight:600;font-size:var(--font-sm);color:var(--lavender);cursor:pointer;text-align:left;background:0 0;border:none;width:100%;padding:8px 10px}.palette-mgr-new-btn:hover{color:var(--soft-black)}.palette-mgr-form{flex-direction:column;gap:8px;display:flex}.palette-mgr-name-input{font-family:Fredoka,sans-serif;font-weight:600;font-size:var(--font-sm);border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);outline:none;padding:6px 10px}.palette-mgr-name-input:focus{border-color:var(--lavender)}.palette-mgr-create-btn{font-size:var(--font-sm)!important;padding:6px 12px!important}.palette-mgr-hint{font-family:Fredoka,sans-serif;font-size:var(--font-xs);color:var(--muted);font-style:italic}.palette-mgr-sublabel{font-family:Fredoka,sans-serif;font-weight:700;font-size:var(--font-xs);color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin:10px 0 6px}.palette-mgr-color-grid{flex-wrap:wrap;gap:6px;display:flex}.palette-mgr-color-item{border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:6px;padding:4px 8px;transition:all .1s;display:flex}.palette-mgr-color-item:hover{background:var(--bg)}.palette-mgr-color-item.hidden{opacity:.3}.palette-mgr-color-item.hidden:hover{opacity:.6}.palette-mgr-color-dot{border:var(--border) solid var(--soft-black);border-radius:50%;flex-shrink:0;width:22px;height:22px;transition:transform .1s}.palette-mgr-color-dot:hover{transform:scale(1.1)}.palette-mgr-color-name{font-family:Fredoka,sans-serif;font-weight:600;font-size:var(--font-xs);color:var(--soft-black)}.palette-mgr-color-removable{position:relative}.palette-mgr-color-remove{background:var(--soft-black);width:14px;height:14px;color:var(--white);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:8px;line-height:1;display:none;position:absolute;top:-2px;right:-2px}.palette-mgr-color-removable:hover .palette-mgr-color-remove{display:flex}.palette-mgr-add-row{flex-wrap:wrap;gap:4px;display:flex}.palette-mgr-add-dot{border:2px solid var(--soft-black);cursor:pointer;border-radius:50%;width:20px;height:20px;transition:transform .1s}.palette-mgr-add-dot:hover{transform:scale(1.15)}.palette-mgr-add-dot.in-palette{opacity:.25;cursor:default}.palette-mgr-reset-btn{font-family:Fredoka,sans-serif;font-weight:600;font-size:var(--font-xs);color:var(--lavender);cursor:pointer;background:0 0;border:none;margin-top:4px;padding:8px 0}.palette-mgr-reset-btn:hover{color:var(--soft-black)}.palette-mgr-custom-picker{align-items:center;gap:8px;display:flex}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#37415166;position:fixed;inset:0}.modal-container{background:var(--white);border:var(--border) solid var(--soft-black);border-radius:var(--radius-lg);width:94vw;max-height:85vh;box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--lavender);flex-direction:column;display:flex;position:fixed;top:50%;left:50%;overflow:hidden;transform:translate(-50%,-50%)}.modal-header{padding:20px 24px 12px;position:relative}.modal-title{font-family:Fredoka,sans-serif;font-size:var(--font-lg);color:var(--soft-black);font-weight:700}.modal-desc{font-size:var(--font-sm);color:var(--muted);margin-top:2px}.modal-close{background:var(--bg);border:var(--border) solid var(--soft-black);border-radius:var(--radius-sm);cursor:pointer;width:32px;height:32px;box-shadow:var(--shadow-x) var(--shadow-y) 0 var(--shadow-color);justify-content:center;align-items:center;padding:0;transition:transform .1s,box-shadow .1s;display:flex;position:absolute;top:16px;right:20px}.modal-close:hover{box-shadow:calc(var(--shadow-x) + 2px) calc(var(--shadow-y) + 2px) 0 var(--shadow-color);transform:translate(-2px,-2px)}.modal-close:active{box-shadow:none;transform:translate(0)}.modal-close:before,.modal-close:after{content:"";width:14px;height:var(--border);background:var(--soft-black);border-radius:1px;position:absolute}.modal-close:before{transform:rotate(45deg)}.modal-close:after{transform:rotate(-45deg)}.modal-sm{max-width:420px}.modal-md{max-width:640px}.modal-lg{max-width:920px}.modal-full{max-width:94vw}:root{--lavender:#c4b5fd;--peach:#fdba74;--mint:#86efac;--soft-black:#374151;--white:#fff;--bg:#f1e3dc;--muted:#9ca3af;--separator:#e5e7eb;--logo-size:500px;--logo-opacity:.06;--header-logo-height:36px;--header-logo-opacity:1;--header-logo-margin-top:0px;--header-logo-margin-right:0px;--border:3px;--radius-sm:8px;--radius-md:12px;--radius-lg:20px;--shadow-x:5px;--shadow-y:5px;--shadow-color:var(--lavender);--btn-size:38px;--swatch-size:28px;--side-width-left:260px;--side-width-right:120px;--font-xs:9px;--font-sm:12px;--font-md:14px;--font-lg:18px;--font-editor:18px;--font-preview:16px;--toolbar-pad:6px;--header-pad:8px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--soft-black);flex-direction:column;height:100vh;font-family:Plus Jakarta Sans,sans-serif;display:flex;overflow:hidden}#root{flex-direction:column;height:100vh;display:flex;overflow:hidden}::selection{background:#c4b5fd66}:focus-visible{outline:var(--border) solid var(--lavender);outline-offset:2px}button{cursor:pointer;font-family:inherit}*{-webkit-user-select:none;user-select:none}.editor,.editor *{-webkit-user-select:text;user-select:text}.shape{pointer-events:none;z-index:0;position:fixed}.shape-1{border:var(--border) dashed var(--peach);opacity:.15;border-radius:50%;width:140px;height:140px;top:40px;left:30px}.shape-2{background:var(--mint);opacity:.2;border-radius:50%;width:14px;height:14px;top:120px;right:80px}.shape-3{border-left:26px solid #0000;border-right:26px solid #0000;border-bottom:45px solid var(--lavender);opacity:.12;width:0;height:0;bottom:60px;right:40px}.shape-4{background:var(--peach);opacity:.12;width:35px;height:35px;top:300px;right:20px;transform:rotate(45deg)}.shape-5{opacity:.1;background-image:radial-gradient(var(--soft-black) 2px,transparent 2px);background-size:12px 12px;width:70px;height:70px;top:180px;left:20px}
