*{margin:0;padding:0;box-sizing:border-box}:root{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.5;font-weight:400;--color-bg-primary: #FAF8F3;--color-bg-card: #FFFFFF;--color-bg-secondary: #F5F2ED;--color-primary: #8B7355;--color-primary-hover: #73614A;--color-primary-light: #A89080;--color-border: #E8E3DB;--color-border-hover: #D4C5B9;--color-text-primary: #2C2C2C;--color-text-secondary: #6B6B6B;--color-text-tertiary: #999999;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 2px 8px rgba(0, 0, 0, .1);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .12);--shadow-xl: 0 8px 24px rgba(0, 0, 0, .15);--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--spacing-xs: .5rem;--spacing-sm: .75rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;color:var(--color-text-primary);background-color:var(--color-bg-primary);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;background-color:var(--color-bg-primary)}#app{width:100%;min-height:100vh}.custom-strike{background:linear-gradient(currentColor,currentColor) no-repeat;background-size:100% 2px;background-position:0 60%;text-decoration:none!important}@font-face{font-family:Caveat;src:url(/fonts/Caveat-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Caveat;src:url(/fonts/Caveat-Medium.ttf) format("truetype");font-weight:500;font-style:normal;font-display:swap}@font-face{font-family:Caveat;src:url(/fonts/Caveat-SemiBold.ttf) format("truetype");font-weight:600;font-style:normal;font-display:swap}@font-face{font-family:Caveat;src:url(/fonts/Caveat-Bold.ttf) format("truetype");font-weight:700;font-style:normal;font-display:swap}@font-face{font-family:Dancing Script;src:url(/fonts/DancingScript-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Dancing Script;src:url(/fonts/DancingScript-Medium.ttf) format("truetype");font-weight:500;font-style:normal;font-display:swap}@font-face{font-family:Dancing Script;src:url(/fonts/DancingScript-SemiBold.ttf) format("truetype");font-weight:600;font-style:normal;font-display:swap}@font-face{font-family:Dancing Script;src:url(/fonts/DancingScript-Bold.ttf) format("truetype");font-weight:700;font-style:normal;font-display:swap}@font-face{font-family:Covered By Your Grace;src:url(/fonts/CoveredByYourGrace-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Gaegu;src:url(/fonts/Gaegu-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Give You Glory;src:url(/fonts/GiveYouGlory-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Handlee;src:url(/fonts/Handlee-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Homemade Apple;src:url(/fonts/HomemadeApple-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Oooh Baby;src:url(/fonts/OoohBaby-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Grape Nuts;src:url(/fonts_vip/GrapeNuts-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Indie Flower;src:url(/fonts_vip/IndieFlower-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Kalam;src:url(/fonts_vip/Kalam-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Liu Jian Mao Cao;src:url(/fonts_vip/LiuJianMaoCao-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Long Cang;src:url(/fonts_vip/LongCang-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Mynerve;src:url(/fonts_vip/Mynerve-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Nanum Brush Script;src:url(/fonts_vip/NanumBrushScript-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Nanum Pen Script;src:url(/fonts_vip/NanumPenScript-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Nothing You Could Do;src:url(/fonts_vip/NothingYouCouldDo-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Over the Rainbow;src:url(/fonts_vip/OvertheRainbow-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Reenie Beanie;src:url(/fonts_vip/ReenieBeanie-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Shadows Into Light;src:url(/fonts_vip/ShadowsIntoLight-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Solitreo;src:url(/fonts_vip/Solitreo-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Sue Ellen Francisco;src:url(/fonts_vip/SueEllenFrancisco-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:The Girl Next Door;src:url(/fonts_vip/TheGirlNextDoor-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Waiting for the Sunrise;src:url(/fonts_vip/WaitingfortheSunrise-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}.language-switcher[data-v-5491b67a]{position:relative}.lang-trigger[data-v-5491b67a]{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);border:1.5px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-card);color:var(--color-text-secondary);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.lang-trigger[data-v-5491b67a]:hover{border-color:var(--color-primary-light);background:var(--color-bg-secondary);color:var(--color-text-primary)}.globe-icon[data-v-5491b67a]{flex-shrink:0}.current-lang[data-v-5491b67a]{min-width:50px}.chevron-icon[data-v-5491b67a]{flex-shrink:0;transition:transform .2s ease}.chevron-icon.open[data-v-5491b67a]{transform:rotate(180deg)}.lang-dropdown[data-v-5491b67a]{position:absolute;top:calc(100% + 4px);right:0;min-width:140px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);overflow:hidden;z-index:1000}.lang-option[data-v-5491b67a]{width:100%;display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:none;color:var(--color-text-primary);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s ease;text-align:left}.lang-option[data-v-5491b67a]:hover{background:var(--color-bg-secondary)}.lang-option.active[data-v-5491b67a]{color:var(--color-primary);background:var(--color-bg-secondary)}.lang-label[data-v-5491b67a]{flex:1}.check-icon[data-v-5491b67a]{flex-shrink:0;color:var(--color-primary)}.dropdown-enter-active[data-v-5491b67a],.dropdown-leave-active[data-v-5491b67a]{transition:all .2s ease}.dropdown-enter-from[data-v-5491b67a],.dropdown-leave-to[data-v-5491b67a]{opacity:0;transform:translateY(-8px)}.dropdown-enter-to[data-v-5491b67a],.dropdown-leave-from[data-v-5491b67a]{opacity:1;transform:translateY(0)}@media(max-width:768px){.lang-trigger[data-v-5491b67a]{padding:var(--spacing-xs)}.current-lang[data-v-5491b67a],.chevron-icon[data-v-5491b67a]{display:none}}.app-header[data-v-64d5b385]{background:var(--color-bg-card);box-shadow:var(--shadow-sm);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:100}.header-container[data-v-64d5b385]{max-width:1600px;margin:0 auto;padding:0 var(--spacing-lg);height:64px;display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-xl)}.header-left[data-v-64d5b385]{display:flex;align-items:center;gap:var(--spacing-sm);flex-shrink:0}.logo[data-v-64d5b385]{display:flex;align-items:center;justify-content:center}.site-name[data-v-64d5b385]{font-size:1.25rem;font-weight:600;color:var(--color-text-primary);white-space:nowrap}.header-nav[data-v-64d5b385]{display:flex;gap:var(--spacing-xs);flex:1;justify-content:center}.nav-btn[data-v-64d5b385]{padding:var(--spacing-xs) var(--spacing-lg);border:1px solid transparent;background:transparent;color:var(--color-text-secondary);font-size:.95rem;font-weight:500;cursor:pointer;border-radius:var(--radius-md);transition:all .2s ease;white-space:nowrap}.nav-btn[data-v-64d5b385]:hover{background:var(--color-bg-secondary);color:var(--color-text-primary);border-color:var(--color-border)}.nav-btn.active[data-v-64d5b385]{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.header-right[data-v-64d5b385]{flex-shrink:0;display:flex;align-items:center;gap:var(--spacing-sm)}.google-login-btn[data-v-64d5b385]{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);background:var(--color-bg-card);border:1.5px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.google-login-btn[data-v-64d5b385]:hover{background:var(--color-bg-secondary);border-color:var(--color-primary-light);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.google-icon[data-v-64d5b385]{flex-shrink:0}.login-text[data-v-64d5b385]{font-weight:500}.user-menu-container[data-v-64d5b385]{position:relative}.user-avatar-btn[data-v-64d5b385]{padding:0;background:transparent;border:2px solid var(--color-border);border-radius:50%;cursor:pointer;transition:all .2s ease;overflow:hidden}.user-avatar-btn[data-v-64d5b385]:hover{border-color:var(--color-primary);transform:scale(1.05);box-shadow:0 0 0 3px #8b73551a}.user-avatar[data-v-64d5b385]{width:40px;height:40px;border-radius:50%;object-fit:cover;display:block}.dropdown-menu[data-v-64d5b385]{position:absolute;top:calc(100% + 8px);right:0;width:280px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;z-index:1000}.dropdown-header[data-v-64d5b385]{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--color-bg-secondary)}.dropdown-avatar[data-v-64d5b385]{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid var(--color-border)}.dropdown-user-info[data-v-64d5b385]{flex:1;min-width:0}.dropdown-user-name[data-v-64d5b385]{display:block;font-size:1rem;font-weight:600;color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:var(--spacing-xs)}.dropdown-tier-badge[data-v-64d5b385]{display:inline-block;padding:4px 10px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.5px}.dropdown-divider[data-v-64d5b385]{height:1px;background:var(--color-border);margin:0}.dropdown-nav[data-v-64d5b385]{padding:var(--spacing-xs) 0}.dropdown-item[data-v-64d5b385]{width:100%;display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:transparent;border:none;color:var(--color-text-primary);font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease;text-align:left}.dropdown-item[data-v-64d5b385]:hover{background:var(--color-bg-secondary)}.dropdown-item svg[data-v-64d5b385]{flex-shrink:0;color:var(--color-text-secondary)}.dropdown-item:hover svg[data-v-64d5b385]{color:var(--color-primary)}.logout-item[data-v-64d5b385]{color:var(--color-error)}.logout-item svg[data-v-64d5b385]{color:var(--color-error)}.logout-item[data-v-64d5b385]:hover{background:#ef44441a}.dropdown-enter-active[data-v-64d5b385],.dropdown-leave-active[data-v-64d5b385]{transition:all .2s ease}.dropdown-enter-from[data-v-64d5b385],.dropdown-leave-to[data-v-64d5b385]{opacity:0;transform:translateY(-8px)}.dropdown-enter-to[data-v-64d5b385],.dropdown-leave-from[data-v-64d5b385]{opacity:1;transform:translateY(0)}.google-login-btn[data-v-64d5b385]:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.header-container[data-v-64d5b385]{padding:0 var(--spacing-md);height:auto;flex-wrap:wrap;padding-top:var(--spacing-sm);padding-bottom:var(--spacing-sm)}.header-nav[data-v-64d5b385]{order:3;width:100%;justify-content:flex-start;overflow-x:auto;padding-bottom:var(--spacing-xs)}.header-right[data-v-64d5b385]{order:2}.google-login-btn[data-v-64d5b385]{padding:var(--spacing-xs) var(--spacing-sm);font-size:.85rem}.login-text[data-v-64d5b385]{display:none}.nav-btn[data-v-64d5b385]{padding:.4rem var(--spacing-md);font-size:.9rem}}.sidebar-section[data-v-8aabc120]{display:flex;flex-direction:column;flex-shrink:0}.sidebar-title[data-v-8aabc120]{margin:0 0 var(--spacing-md) 0;font-size:1rem;font-weight:700;color:var(--color-text-primary);flex-shrink:0}.font-cards[data-v-8aabc120]{display:flex;flex-direction:column;gap:var(--spacing-sm);overflow-y:auto;height:360px;scrollbar-width:none;-ms-overflow-style:none;position:relative}.font-cards[data-v-8aabc120]::-webkit-scrollbar{display:none}.virtual-scroll-container[data-v-8aabc120]{position:relative;width:100%}.virtual-scroll-content[data-v-8aabc120]{display:flex;flex-direction:column;gap:var(--spacing-sm);will-change:transform}.font-card[data-v-8aabc120]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-md);border:1.5px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-secondary);cursor:pointer;transition:all .2s;height:80px;flex-shrink:0;position:relative}.font-card[data-v-8aabc120]:hover{border-color:var(--color-primary-light);background:var(--color-bg-card);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.font-card.active[data-v-8aabc120]{border-color:var(--color-primary);background:var(--color-primary);box-shadow:var(--shadow-md)}.font-card.locked[data-v-8aabc120]{cursor:not-allowed;opacity:.7}.font-card.locked[data-v-8aabc120]:hover{border-color:var(--color-border);background:var(--color-bg-secondary);box-shadow:none;transform:none}.font-preview[data-v-8aabc120]{font-size:32px;line-height:1;margin-bottom:var(--spacing-xs);color:var(--color-text-primary)}.font-card.active .font-preview[data-v-8aabc120]{color:#fff}.font-card.locked .font-preview[data-v-8aabc120]{opacity:.5}.font-name[data-v-8aabc120]{font-size:.85rem;color:var(--color-text-secondary)}.font-card.active .font-name[data-v-8aabc120]{color:#fffffff2}.font-card.locked .font-name[data-v-8aabc120]{opacity:.5}.upload-card[data-v-8aabc120]{border-style:dashed}.upload-icon[data-v-8aabc120]{font-size:24px;margin-bottom:var(--spacing-xs);color:var(--color-text-secondary)}.hidden-input[data-v-8aabc120]{display:none}.sidebar-section[data-v-51922944]{margin-bottom:var(--spacing-lg)}.sidebar-title[data-v-51922944]{font-size:1rem;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-md)}.adjustment-controls[data-v-51922944]{display:flex;flex-direction:column;gap:var(--spacing-md)}.control-item[data-v-51922944]{display:flex;flex-direction:column;gap:var(--spacing-xs)}.control-label[data-v-51922944]{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;color:var(--color-text-secondary);font-weight:500}.control-value[data-v-51922944]{color:var(--color-primary);font-weight:600;min-width:50px;text-align:right}.slider[data-v-51922944]{width:100%;height:6px;border-radius:3px;background:var(--color-bg-secondary);outline:none;-webkit-appearance:none;appearance:none;cursor:pointer}.slider[data-v-51922944]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--color-primary);cursor:pointer;transition:all .2s}.slider[data-v-51922944]::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 0 0 4px #8b735533}.slider[data-v-51922944]::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:none;transition:all .2s}.slider[data-v-51922944]::-moz-range-thumb:hover{transform:scale(1.2);box-shadow:0 0 0 4px #8b735533}.margin-controls[data-v-51922944]{margin-top:var(--spacing-xs)}.margin-grid[data-v-51922944]{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm)}.margin-input-group[data-v-51922944]{display:flex;flex-direction:column;gap:4px}.margin-input-group label[data-v-51922944]{font-size:.75rem;color:var(--color-text-tertiary);font-weight:500}.margin-input[data-v-51922944]{width:100%;padding:var(--spacing-xs);border:1.5px solid var(--color-border);border-radius:var(--radius-sm);font-size:.85rem;color:var(--color-text-primary);background:var(--color-bg-card);transition:all .2s}.margin-input[data-v-51922944]:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #8b73551a}.margin-input[data-v-51922944]::-webkit-inner-spin-button,.margin-input[data-v-51922944]::-webkit-outer-spin-button{opacity:1}.personalization-adjustment[data-v-0a403ed6]{display:flex;flex-direction:column;gap:var(--spacing-md)}.section-title[data-v-0a403ed6]{font-size:1rem;font-weight:700;color:var(--color-text-primary);margin:0;padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--color-border)}.adjustment-section[data-v-0a403ed6]{display:flex;flex-direction:column;gap:var(--spacing-lg)}.control-group[data-v-0a403ed6]{display:flex;flex-direction:column;gap:var(--spacing-sm)}.section-label[data-v-0a403ed6]{font-size:.9rem;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.radio-group[data-v-0a403ed6]{display:flex;flex-direction:column;gap:var(--spacing-xs)}.radio-option[data-v-0a403ed6]{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.9rem;color:var(--color-text-secondary);cursor:pointer;padding:var(--spacing-xs);border-radius:var(--radius-sm);transition:all .2s}.radio-option[data-v-0a403ed6]:hover{background:var(--color-bg-secondary)}.radio-option input[type=radio][data-v-0a403ed6]{width:16px;height:16px;cursor:pointer;accent-color:var(--color-primary)}.radio-option span[data-v-0a403ed6]{-webkit-user-select:none;user-select:none}.control-group label[data-v-0a403ed6]{font-size:.9rem;font-weight:600;color:var(--color-text-primary);display:flex;justify-content:space-between;align-items:center}.control-group .value[data-v-0a403ed6]{font-weight:700;color:var(--color-primary);min-width:50px;text-align:right}.control-group input[type=range][data-v-0a403ed6]{width:100%;height:6px;border-radius:3px;background:var(--color-bg-secondary);outline:none;-webkit-appearance:none}.control-group input[type=range][data-v-0a403ed6]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--color-primary);cursor:pointer;transition:all .2s}.control-group input[type=range][data-v-0a403ed6]::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 0 0 4px #8b735533}.control-group input[type=range][data-v-0a403ed6]::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:none;transition:all .2s}.control-group input[type=range][data-v-0a403ed6]::-moz-range-thumb:hover{transform:scale(1.2);box-shadow:0 0 0 4px #8b735533}.hint[data-v-0a403ed6]{font-size:.75rem;color:var(--color-text-tertiary);font-style:italic;margin-top:-4px}.sidebar-section[data-v-118ee779]{display:flex;flex-direction:column;flex-shrink:0}.sidebar-title[data-v-118ee779]{margin:0 0 var(--spacing-md) 0;font-size:1rem;font-weight:700;color:var(--color-text-primary);flex-shrink:0}.background-options[data-v-118ee779]{display:grid;grid-template-columns:1fr;gap:var(--spacing-sm);overflow-y:auto;overflow-x:hidden;height:400px;align-content:start;scrollbar-width:none;-ms-overflow-style:none;position:relative}.background-options[data-v-118ee779]::-webkit-scrollbar{display:none}.virtual-scroll-container[data-v-118ee779]{position:relative;width:100%}.virtual-scroll-content[data-v-118ee779]{display:grid;grid-template-columns:1fr;gap:var(--spacing-sm);will-change:transform}.bg-option[data-v-118ee779]{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-sm);border:1.5px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-card);cursor:pointer;transition:all .2s;height:87px;flex-shrink:0}.bg-option[data-v-118ee779]:hover{border-color:var(--color-primary-light);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.bg-option.active[data-v-118ee779]{border-color:var(--color-primary);background:var(--color-bg-secondary);box-shadow:var(--shadow-md)}.bg-option.locked[data-v-118ee779]{cursor:not-allowed;opacity:.7}.bg-option.locked[data-v-118ee779]:hover{border-color:var(--color-border);background:var(--color-bg-card);box-shadow:none;transform:none}.bg-preview[data-v-118ee779]{width:60px;height:60px;border:1px solid var(--color-border);border-radius:var(--radius-sm);margin-bottom:var(--spacing-xs);background-size:cover;background-position:center;position:relative}.bg-option.locked .bg-preview[data-v-118ee779]{opacity:.5}.bg-name[data-v-118ee779]{font-size:.8rem;color:var(--color-text-secondary)}.bg-option.active .bg-name[data-v-118ee779]{color:var(--color-text-primary);font-weight:600}.bg-option.locked .bg-name[data-v-118ee779]{opacity:.5}.lock-icon[data-v-118ee779]{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:24px;height:24px;pointer-events:none;z-index:1}.toolbar[data-v-e92b2db2]{background:var(--color-bg-card);padding:var(--spacing-lg);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-md);display:flex;flex-wrap:wrap;gap:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.toolbar-group[data-v-e92b2db2]{display:flex;align-items:center;gap:var(--spacing-xs)}.toolbar-group label[data-v-e92b2db2]{font-weight:600;color:var(--color-text-primary);font-size:.9rem}.weight-buttons[data-v-e92b2db2],.align-buttons[data-v-e92b2db2]{display:flex;gap:var(--spacing-xs)}.weight-btn[data-v-e92b2db2],.align-btn[data-v-e92b2db2]{width:40px;height:40px;padding:0;border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:1rem;font-weight:700;font-style:normal;cursor:pointer;background:var(--color-bg-card);color:var(--color-text-primary);transition:all .2s;display:flex;align-items:center;justify-content:center}.weight-btn[data-v-e92b2db2]:hover:not(:disabled),.align-btn[data-v-e92b2db2]:hover{border-color:var(--color-primary-light);background:var(--color-bg-secondary)}.weight-btn.active[data-v-e92b2db2],.align-btn.active[data-v-e92b2db2]{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.weight-btn.disabled[data-v-e92b2db2]{background:var(--color-bg-secondary);color:var(--color-text-tertiary);cursor:not-allowed;border-color:var(--color-border)}.weight-btn[data-v-e92b2db2]:last-child{font-style:italic}.color-picker-wrapper[data-v-e92b2db2]{position:relative}.color-btn[data-v-e92b2db2]{width:40px;height:40px;padding:0;border:1.5px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.color-btn[data-v-e92b2db2]:hover{border-color:var(--color-primary);transform:scale(1.05)}.color-panel[data-v-e92b2db2]{position:absolute;top:calc(100% + 8px);left:0;background:var(--color-bg-card);border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);box-shadow:var(--shadow-lg);z-index:1000;min-width:240px}.preset-colors[data-v-e92b2db2]{display:grid;grid-template-columns:repeat(6,1fr);gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.preset-color[data-v-e92b2db2]{width:32px;height:32px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s}.preset-color[data-v-e92b2db2]:hover{transform:scale(1.1);border-color:var(--color-primary)}.preset-color.active[data-v-e92b2db2]{border-color:var(--color-primary);border-width:2.5px;transform:scale(1.1)}.custom-color[data-v-e92b2db2]{display:flex;align-items:center;gap:var(--spacing-xs);padding-top:var(--spacing-xs);border-top:1px solid var(--color-border)}.custom-color label[data-v-e92b2db2]{font-size:.85rem;color:var(--color-text-secondary);font-weight:400}.custom-color input[type=color][data-v-e92b2db2]{width:60px;height:32px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer}.action-buttons[data-v-e92b2db2]{margin-left:auto}.generate-btn[data-v-e92b2db2],.download-btn[data-v-e92b2db2]{padding:var(--spacing-xs) var(--spacing-lg);border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all .25s}.secondary-btn[data-v-e92b2db2]{padding:var(--spacing-xs) var(--spacing-md);border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:.9rem;font-weight:600;cursor:pointer;background:var(--color-bg-card);color:var(--color-text-primary);display:flex;align-items:center;gap:6px;transition:all .2s}.secondary-btn[data-v-e92b2db2]:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-bg-secondary)}.generate-btn[data-v-e92b2db2]{background:var(--color-primary);color:#fff;border:1.5px solid var(--color-primary)}.generate-btn[data-v-e92b2db2]:hover{background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.download-btn[data-v-e92b2db2]{background:#6b9d5a;color:#fff;border:1.5px solid #6B9D5A}.download-btn[data-v-e92b2db2]:hover:not(:disabled){background:#5a8549;transform:translateY(-1px);box-shadow:var(--shadow-md)}.download-btn[data-v-e92b2db2]:disabled{background:var(--color-border);border-color:var(--color-border);color:var(--color-text-tertiary);cursor:not-allowed}.selection-toolbar[data-v-48ad25b5]{position:absolute;background:var(--color-bg-card);border:2px solid var(--color-primary);border-radius:var(--radius-md);padding:var(--spacing-xs);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:var(--spacing-xs);z-index:100}.toolbar-item[data-v-48ad25b5]{display:flex;align-items:center;gap:.25rem}.toolbar-divider[data-v-48ad25b5]{width:1px;height:24px;background:var(--color-border)}.weight-btn[data-v-48ad25b5],.style-btn[data-v-48ad25b5]{min-width:32px;height:32px;padding:0 var(--spacing-xs);border:1.5px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-card);font-size:.9rem;font-weight:600;color:var(--color-text-primary);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.weight-btn[data-v-48ad25b5]:hover,.style-btn[data-v-48ad25b5]:hover{border-color:var(--color-primary-light);background:var(--color-bg-secondary)}.weight-btn.active[data-v-48ad25b5],.style-btn.active[data-v-48ad25b5]{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.selection-color-btn[data-v-48ad25b5]{width:32px;height:32px;padding:0;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.selection-color-btn[data-v-48ad25b5]:hover{border-color:var(--color-primary);transform:scale(1.05)}.color-picker-wrapper[data-v-48ad25b5]{position:relative}.color-panel[data-v-48ad25b5]{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--color-bg-card);border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);box-shadow:var(--shadow-lg);z-index:1000;min-width:240px}.preset-colors[data-v-48ad25b5]{display:grid;grid-template-columns:repeat(6,1fr);gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.preset-color[data-v-48ad25b5]{width:32px;height:32px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s}.preset-color[data-v-48ad25b5]:hover{transform:scale(1.1);border-color:var(--color-primary)}.preset-color.active[data-v-48ad25b5]{border-color:var(--color-primary);border-width:2.5px;transform:scale(1.1)}.custom-color[data-v-48ad25b5]{display:flex;align-items:center;gap:var(--spacing-xs);padding-top:var(--spacing-xs);border-top:1px solid var(--color-border)}.custom-color label[data-v-48ad25b5]{font-size:.85rem;color:var(--color-text-secondary);font-weight:400}.custom-color input[type=color][data-v-48ad25b5]{width:60px;height:32px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer}.input-section[data-v-33d0bf75]{flex:1;background:var(--color-bg-card);padding:var(--spacing-xl);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-md);min-width:0}.handwriting-input[data-v-33d0bf75]{width:100%;height:600px;padding:var(--spacing-md);border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:24px;line-height:1.8;resize:none;transition:border-color .3s;background:#fff;background-size:100% auto;background-repeat:repeat-y;background-position:top left;overflow-y:auto;word-wrap:break-word;color:var(--color-text-primary)}.handwriting-input[data-v-33d0bf75]:focus{outline:none;border-color:var(--color-primary-light);box-shadow:0 0 0 3px #8b73551a}.handwriting-input[data-v-33d0bf75]:empty:before{content:attr(data-placeholder);color:var(--color-text-tertiary);pointer-events:none}.clear-btn[data-v-33d0bf75]{position:absolute;top:var(--spacing-xl);right:var(--spacing-xl);width:32px;height:32px;padding:0;border:none;background:transparent;color:var(--color-text-tertiary);cursor:pointer;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:10}.clear-btn[data-v-33d0bf75]:hover{background:var(--color-bg-secondary);color:var(--color-error)}.preview-section[data-v-e4d957f4]{flex:1;background:var(--color-bg-card);padding:var(--spacing-xl);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-md);display:flex;flex-direction:column}.preview-container[data-v-e4d957f4]{flex:1;display:flex;justify-content:center;align-items:flex-start;overflow-y:auto;max-height:600px}.preview-image[data-v-e4d957f4]{max-width:100%;height:auto;border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md)}.preview-placeholder[data-v-e4d957f4]{flex:1;display:flex;align-items:center;justify-content:center;height:600px;border:2px dashed var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-secondary);color:var(--color-text-tertiary)}.preview-placeholder p[data-v-e4d957f4]{margin:0;font-size:1rem}.modal-overlay[data-v-bde589e2]{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:9999;padding:var(--spacing-lg)}.modal-content[data-v-bde589e2]{background:var(--color-bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:100%;max-width:1200px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.modal-header[data-v-bde589e2]{padding:var(--spacing-lg);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.modal-header h2[data-v-bde589e2]{font-size:1.5rem;font-weight:700;color:var(--color-text-primary);margin:0}.close-btn[data-v-bde589e2]{width:36px;height:36px;padding:0;border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;border-radius:var(--radius-md);transition:all .2s;display:flex;align-items:center;justify-content:center}.close-btn[data-v-bde589e2]:hover{background:var(--color-bg-secondary);color:var(--color-text-primary)}.modal-body[data-v-bde589e2]{display:flex;gap:var(--spacing-lg);padding:var(--spacing-lg);overflow:auto;flex:1}.preview-section[data-v-bde589e2]{flex:1;display:flex;align-items:center;justify-content:center;background:var(--color-bg-secondary);border-radius:var(--radius-md);padding:var(--spacing-lg);min-height:400px}.preview-container[data-v-bde589e2]{max-width:100%;max-height:100%;overflow:auto;display:flex;align-items:center;justify-content:center}.preview-container canvas[data-v-bde589e2]{display:block;max-width:100%;height:auto;box-shadow:var(--shadow-md)}.controls-section[data-v-bde589e2]{width:300px;flex-shrink:0;display:flex;flex-direction:column;gap:var(--spacing-lg)}.control-group[data-v-bde589e2]{display:flex;flex-direction:column;gap:var(--spacing-sm)}.control-group label[data-v-bde589e2]{font-size:.95rem;font-weight:600;color:var(--color-text-primary);display:flex;justify-content:space-between;align-items:center}.control-group .value[data-v-bde589e2]{font-weight:700;color:var(--color-primary);min-width:40px;text-align:right}.control-group input[type=range][data-v-bde589e2]{width:100%;height:6px;border-radius:3px;background:var(--color-bg-secondary);outline:none;-webkit-appearance:none}.control-group input[type=range][data-v-bde589e2]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--color-primary);cursor:pointer;transition:all .2s}.control-group input[type=range][data-v-bde589e2]::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 0 0 4px #667eea33}.control-group input[type=range][data-v-bde589e2]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:none;transition:all .2s}.control-group input[type=range][data-v-bde589e2]::-moz-range-thumb:hover{transform:scale(1.2);box-shadow:0 0 0 4px #667eea33}.button-group[data-v-bde589e2]{display:flex;gap:var(--spacing-md);margin-top:auto;padding-top:var(--spacing-lg)}.reset-btn[data-v-bde589e2],.confirm-btn[data-v-bde589e2]{flex:1;padding:var(--spacing-md) var(--spacing-lg);border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all .25s}.reset-btn[data-v-bde589e2]{background:var(--color-bg-secondary);color:var(--color-text-primary);border:1.5px solid var(--color-border)}.reset-btn[data-v-bde589e2]:hover{background:var(--color-bg-card);border-color:var(--color-primary);color:var(--color-primary)}.confirm-btn[data-v-bde589e2]{background:var(--color-primary);color:#fff;border:1.5px solid var(--color-primary)}.confirm-btn[data-v-bde589e2]:hover{background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}@media(max-width:768px){.modal-body[data-v-bde589e2]{flex-direction:column}.controls-section[data-v-bde589e2]{width:100%}.preview-section[data-v-bde589e2]{min-height:300px}}.notification-modal-overlay[data-v-1a96cea4]{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem}.notification-modal-content[data-v-1a96cea4]{background:var(--color-background-card, #FFFFFF);border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-xl, 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04));max-width:500px;width:100%;overflow:hidden;animation:modal-slide-in-1a96cea4 .3s ease-out}.notification-modal-header[data-v-1a96cea4]{padding:1.5rem 1.5rem 1rem;border-bottom:1px solid var(--color-border, #E8E3DB)}.notification-modal-title[data-v-1a96cea4]{margin:0;font-size:1.25rem;font-weight:600;color:var(--color-text-primary, #2C2C2C)}.notification-modal-body[data-v-1a96cea4]{padding:1.5rem}.notification-modal-message[data-v-1a96cea4]{margin:0;font-size:1rem;line-height:1.6;color:var(--color-text-secondary, #6B6B6B)}.notification-modal-footer[data-v-1a96cea4]{padding:1rem 1.5rem 1.5rem;display:flex;justify-content:flex-end;gap:.75rem}.notification-confirm-btn[data-v-1a96cea4]{padding:.625rem 1.5rem;background:var(--color-primary, #8B7355);color:#fff;border:none;border-radius:var(--radius-md, 8px);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:80px}.notification-confirm-btn[data-v-1a96cea4]:hover{background:var(--color-primary-dark, #73614A);transform:translateY(-1px);box-shadow:0 4px 6px -1px #8b73554d}.notification-confirm-btn[data-v-1a96cea4]:active{transform:translateY(0)}.modal-fade-enter-active[data-v-1a96cea4],.modal-fade-leave-active[data-v-1a96cea4]{transition:opacity .3s ease}.modal-fade-enter-from[data-v-1a96cea4],.modal-fade-leave-to[data-v-1a96cea4]{opacity:0}.modal-fade-enter-active .notification-modal-content[data-v-1a96cea4]{animation:modal-slide-in-1a96cea4 .3s ease-out}.modal-fade-leave-active .notification-modal-content[data-v-1a96cea4]{animation:modal-slide-out-1a96cea4 .3s ease-in}@keyframes modal-slide-in-1a96cea4{0%{transform:translateY(-20px) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}@keyframes modal-slide-out-1a96cea4{0%{transform:translateY(0) scale(1);opacity:1}to{transform:translateY(-20px) scale(.95);opacity:0}}@media(max-width:640px){.notification-modal-content[data-v-1a96cea4]{max-width:calc(100vw - 2rem)}.notification-modal-header[data-v-1a96cea4],.notification-modal-body[data-v-1a96cea4],.notification-modal-footer[data-v-1a96cea4]{padding-left:1rem;padding-right:1rem}}#app[data-v-22754ebb]{min-height:100vh;background:var(--color-bg-primary)}.app-container[data-v-22754ebb]{max-width:1600px;margin:0 auto;padding:0 var(--spacing-lg)}.content-layout[data-v-22754ebb]{display:flex;gap:var(--spacing-md);padding-bottom:var(--spacing-lg)}.sidebar[data-v-22754ebb]{width:240px;flex-shrink:0}.sidebar-container[data-v-22754ebb]{background:var(--color-bg-card);border-radius:var(--radius-lg);border:1px solid var(--color-border);padding:var(--spacing-lg);box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:var(--spacing-lg)}.main-container[data-v-22754ebb]{flex:1;min-width:0}.main-content[data-v-22754ebb]{display:flex;gap:var(--spacing-lg);align-items:stretch}.editor-container[data-v-22754ebb]{flex:1;min-width:0}.module-header[data-v-22754ebb]{padding:var(--spacing-lg) 0}.module-title[data-v-22754ebb]{font-size:2rem;font-weight:700;color:var(--color-text-primary);margin-bottom:var(--spacing-xs);line-height:1.2}.module-desc[data-v-22754ebb]{font-size:1.1rem;color:var(--color-text-secondary);line-height:1.5}@media(max-width:1200px){.content-layout[data-v-22754ebb]{flex-direction:column}.sidebar[data-v-22754ebb]{width:100%;height:auto;flex-direction:row;overflow-x:auto}.main-content[data-v-22754ebb]{flex-direction:column}}
