*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.sr-only{white-space:nowrap;border-width:0}.visible{visibility:visible}:root{--bg-primary:#faf7f2;--bg-card:#fff;--accent:#c45c4a;--accent-hover:#a84a3a;--accent-soft:rgba(196,92,74,.12);--text-primary:#2c2c2c;--text-secondary:#6b6b6b;--border:#e8e2d9;--shadow-card:0 4px 24px rgba(44,44,44,.08)}*{box-sizing:border-box}body,html{margin:0;padding:0;min-height:100%;font-family:DM Sans,system-ui,sans-serif;background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}.app-shell{max-width:480px;margin:0 auto;min-height:100dvh;padding-bottom:32px}.page-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px}.logo{font-weight:700;font-size:18px;letter-spacing:-.02em}.badge-free,.logo span{color:var(--accent)}.badge-free{font-size:11px;font-weight:600;background:var(--accent-soft);padding:4px 10px;border-radius:999px}.back-btn{font-size:14px;color:var(--text-secondary)}.hero{padding:8px 20px 24px;text-align:center}.hero h1{font-size:26px;line-height:1.25;margin-bottom:12px}.subtitle{font-size:15px;color:var(--text-secondary);line-height:1.5;margin-bottom:20px}.btn{display:inline-flex;align-items:center;justify-content:center;width:100%;padding:14px 20px;border-radius:12px;font-family:inherit;font-size:15px;font-weight:600;border:none;cursor:pointer;transition:background .15s,opacity .15s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{background:#fff;color:var(--text-primary);border:1px solid var(--border)}.btn-ghost{background:transparent;color:var(--text-secondary)}.w-full{width:100%}.carousel{padding:0 16px 24px}.compare-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.compare-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);margin-bottom:6px}.compare-img{border-radius:12px;overflow:hidden;background:#fff;border:1px solid var(--border)}.compare-img img{width:100%;height:auto;display:block}.carousel-dots{display:flex;justify-content:center;gap:6px;margin-top:12px}.carousel-dots button{width:6px;height:6px;border-radius:50%;border:none;background:var(--border);padding:0}.carousel-dots button.active{background:var(--accent)}.how-it-works{padding:0 20px 24px}.how-it-works h2{font-size:16px;margin-bottom:12px}.steps{list-style:none;padding:0;margin:0;gap:12px}.steps,.steps li{display:flex;flex-direction:column}.steps li{gap:2px;font-size:13px;color:var(--text-secondary)}.steps strong{color:var(--text-primary);font-size:14px}.disclaimer-box{margin:0 20px 24px;padding:12px 14px;font-size:12px;color:#8a8a8a;background:rgba(0,0,0,.03);border-radius:8px;text-align:center}.footer-links{display:flex;justify-content:center;gap:16px;font-size:12px;color:var(--text-secondary);padding:0 20px}.page-content{padding:0 20px 32px}.step-badge{font-size:11px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}.page-content h1{font-size:24px;margin-bottom:8px}.upload-zone{display:flex;flex-direction:column;align-items:center;padding:32px 16px;border:2px dashed var(--border);border-radius:16px;background:#fff;margin:20px 0;cursor:pointer}.upload-icon{font-size:32px;margin-bottom:8px}.upload-hint,.upload-note{font-size:12px;color:var(--text-secondary);margin-top:4px}.field-label{display:block;font-size:13px;font-weight:600;margin:16px 0 8px}.text-input{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:10px;font-family:inherit;font-size:15px;background:#fff}.segmented{display:flex;gap:8px}.segmented button{flex:1;padding:10px;border-radius:10px;border:1px solid var(--border);background:#fff;font-family:inherit;cursor:pointer}.segmented button.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent);font-weight:600}.blessing-list{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}.blessing-card{display:block;padding:12px 14px;border:1px solid var(--border);border-radius:10px;background:#fff;cursor:pointer;font-size:13px}.blessing-card input{display:none}.blessing-card.selected{border-color:var(--accent);background:var(--accent-soft)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.keepsake-card{aspect-ratio:4/5;width:100%;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'%3E%3Cpath d='M0 40h80M40 0v80' stroke='%23C45C4A' stroke-width='0.3' opacity='0.06'/%3E%3C/svg%3E"),linear-gradient(168deg,#fffef9,#f8f2ea 45%,#f0e8dc);border:2px solid var(--accent);border-radius:14px 14px 52px 52px;overflow:hidden;position:relative;box-shadow:var(--shadow-card)}.keepsake-card:before{content:"";position:absolute;inset:10px 10px 14px;border:1px solid rgba(196,92,74,.22);border-radius:8px 8px 40px 40px;pointer-events:none;z-index:2}.keepsake-card--compact .card-blessing,.keepsake-card--compact .card-corner,.keepsake-card--compact .preview-badge{display:none}.keepsake-card--compact .card-name{font-size:10px;letter-spacing:.06em}.keepsake-card--compact .card-footer{padding:8px 6px 10px}.keepsake-card--compact .card-portrait{height:52%}.keepsake-card--mini{transform:scale(.92);transform-origin:top center}.card-string{top:0;width:2px;height:14%;background:var(--accent)}.card-knot,.card-string{position:absolute;left:50%;transform:translateX(-50%);z-index:4}.card-knot{top:11%;width:18px;height:8px;border:1.5px solid var(--accent);border-radius:4px;background:rgba(255,254,249,.9)}.preview-badge{position:absolute;bottom:32%;right:10%;padding:3px 8px;font-size:8px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(44,44,44,.35);border:1px solid rgba(44,44,44,.12);border-radius:4px;z-index:10}.keepsake-card.watermarked .card-portrait:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(-35deg,transparent,transparent 18px,rgba(44,44,44,.025) 0,rgba(44,44,44,.025) 19px);z-index:2}.card-portrait{position:absolute;top:16%;left:12%;right:12%;height:48%;border-radius:6px 6px 20px 20px;overflow:hidden;border:1px solid rgba(196,92,74,.15)}.card-portrait img{width:100%;height:100%;object-fit:cover;filter:saturate(1.05) contrast(1.02)}.card-footer{position:absolute;bottom:0;left:0;right:0;padding:14px 12px 20px;text-align:center;background:linear-gradient(0deg,rgba(255,254,249,.98) 70%,transparent);z-index:3}.card-name{font-size:18px;font-weight:700;letter-spacing:.12em}.card-blessing,.card-name{font-family:"Noto Serif JP",Georgia,serif}.card-blessing{font-size:11px;font-style:italic;color:var(--text-secondary)}.card-corner{position:absolute;top:10px;right:10px;width:16px;height:16px;opacity:.35;z-index:3}.card-corner svg{width:100%;height:100%;fill:var(--accent)}.generating-content{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100dvh;padding:40px 32px;text-align:center}.charm-illustration{width:100px;height:140px;position:relative;margin-bottom:24px}.charm-body{width:100%;height:100%;border:2px solid var(--accent);border-radius:12px 12px 48px 48px;display:flex;align-items:center;justify-content:center;font-size:32px;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.03)}}.progress-bar{width:100%;max-width:240px;height:4px;background:var(--border);border-radius:2px;margin-top:24px;overflow:hidden}.progress-bar-fill{height:100%;width:40%;background:var(--accent);animation:indeterminate 1.5s ease-in-out infinite}@keyframes indeterminate{0%{transform:translateX(-100%)}to{transform:translateX(350%)}}.preview-screen{max-width:480px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column}.preview-scroll{flex:1;overflow-y:auto;padding:0 20px 120px}.preview-hero{max-width:260px;margin:0 auto 12px}.preview-hero .keepsake-card{box-shadow:0 12px 40px rgba(44,44,44,.12)}.variation-section{margin-top:8px}.variation-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#8a8a8a;margin:0 0 12px;text-align:center}.variation-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;max-width:320px;margin:0 auto}.variation-thumb{display:flex;flex-direction:column;align-items:center;gap:8px;border:none;background:none;padding:0;cursor:pointer;-webkit-appearance:none;appearance:none}.variation-thumb:active{transform:scale(.98)}.variation-thumb__frame{width:100%;aspect-ratio:4/5;border-radius:10px 10px 24px 24px;overflow:hidden;border:2px solid var(--border);background:linear-gradient(168deg,#fffef9,#f0e8dc);transition:border-color .2s,box-shadow .2s}.variation-thumb__frame img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(1.05) contrast(1.02)}.variation-thumb.selected .variation-thumb__frame{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.variation-thumb__label{font-size:11px;font-weight:500;color:var(--text-secondary)}.variation-thumb.selected .variation-thumb__label{color:var(--accent);font-weight:700}.preview-actions{display:flex;flex-direction:column;gap:10px;margin-top:16px}.checkout-dock{position:sticky;bottom:0;padding:16px 20px;background:linear-gradient(to top,var(--bg-primary) 80%,transparent);border-top:1px solid var(--border)}.checkout-note{font-size:11px;color:var(--text-secondary);text-align:center;margin-top:8px}.success-content{max-width:480px;margin:0 auto;padding:40px 20px;text-align:center}.success-icon{width:64px;height:64px;background:var(--accent-soft);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto 16px}.success-card-wrap{max-width:220px;margin:0 auto 24px}.success-actions{display:flex;flex-direction:column;gap:10px}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);display:flex;align-items:flex-end;justify-content:center;padding:20px;z-index:100}.modal-card{width:100%;max-width:400px;background:#fff;border-radius:20px 20px 12px 12px;padding:24px 20px;display:flex;flex-direction:column;gap:12px}.modal-card h3{font-size:20px}.modal-card p{font-size:14px;color:var(--text-secondary);line-height:1.5}.legal-page{max-width:640px;margin:0 auto;padding:32px 20px;line-height:1.6}.legal-page h1{font-size:24px;margin-bottom:16px}