.heart-container{position:relative;width:min(100%,calc(20vh - 10px));aspect-ratio:1 / 1;display:flex;align-items:center;justify-content:center;overflow:hidden}.heart-image{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain;pointer-events:none;-webkit-user-select:none;user-select:none}.heart-character{position:relative;z-index:1;font-family:var(--font-ethiopic),var(--font-display),serif;font-size:min(40cqw,65px);font-weight:500;color:#000;line-height:1;text-align:center;-webkit-user-select:none;user-select:none;margin-top:-5%}.heart-container{container-type:size}.page{width:100%;max-width:595px;aspect-ratio:210 / 297;background:#fff;box-shadow:0 1px 3px var(--color-shadow),0 4px 12px var(--color-shadow),0 8px 24px var(--color-shadow);border-radius:2px;overflow:hidden;position:relative}.page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border:1px solid var(--color-border);pointer-events:none;border-radius:2px}.page-inner{width:100%;height:100%;padding:3%;display:flex;align-items:center;justify-content:center}.hearts-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(5,1fr);gap:1%;width:100%;height:100%}.heart-cell{display:flex;align-items:center;justify-content:center;min-width:0;min-height:0}.page[data-page]:after{content:"Page " attr(data-page);position:absolute;bottom:8px;right:12px;font-family:var(--font-display);font-size:.7rem;color:var(--color-ink-soft);opacity:.5;letter-spacing:.05em}@media print{.page{box-shadow:none;border-radius:0;page-break-after:always}.page:after{display:none}.page:before{display:none}}.app{min-height:100vh;display:flex;flex-direction:column}.header{background:linear-gradient(180deg,var(--color-paper) 0%,var(--color-cream) 100%);border-bottom:1px solid var(--color-border);padding:var(--space-xl) var(--space-lg)}.header-content{max-width:1200px;margin:0 auto;text-align:center}.logo{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);margin-bottom:var(--space-xs)}.logo-icon{width:36px;height:36px;fill:var(--color-burgundy)}.logo-text{font-family:var(--font-display);font-size:2rem;font-weight:500;color:var(--color-ink);letter-spacing:-.02em}.tagline{font-family:var(--font-display);font-size:1.1rem;font-style:italic;color:var(--color-ink-soft);letter-spacing:.02em}.main{flex:1;padding:var(--space-2xl) var(--space-lg);max-width:1200px;margin:0 auto;width:100%}.input-section{margin-bottom:var(--space-2xl)}.input-card{background:#fff;border-radius:8px;padding:var(--space-xl);box-shadow:0 1px 2px var(--color-shadow),0 4px 12px var(--color-shadow);border:1px solid var(--color-border);max-width:600px;margin:0 auto}.input-label{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--font-display);font-size:1rem;font-weight:500;color:var(--color-ink);margin-bottom:var(--space-sm);letter-spacing:.02em}.char-count{font-size:.85rem;font-weight:400;color:var(--color-ink-soft);font-style:italic}.text-input{width:100%;padding:var(--space-md);font-family:var(--font-ethiopic),var(--font-display),serif;font-size:1.25rem;line-height:1.6;color:var(--color-ink);background:var(--color-paper);border:2px solid var(--color-border);border-radius:6px;resize:vertical;min-height:120px;transition:border-color .2s ease,box-shadow .2s ease}.text-input:focus{outline:none;border-color:var(--color-burgundy-light);box-shadow:0 0 0 3px #8b26351a}.text-input::placeholder{color:var(--color-ink-soft);opacity:.6;font-style:italic}.input-actions{display:flex;gap:var(--space-md);margin-top:var(--space-lg);justify-content:flex-end}.btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);font-family:var(--font-display);font-size:1rem;font-weight:500;letter-spacing:.02em;border-radius:6px;border:none;cursor:pointer;transition:all .2s ease}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-burgundy);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-burgundy-light);transform:translateY(-1px);box-shadow:0 4px 12px #8b26354d}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:transparent;color:var(--color-ink-soft);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-paper);color:var(--color-ink);border-color:var(--color-ink-soft)}.btn-icon{width:18px;height:18px}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.preview-section{text-align:center}.preview-title{font-family:var(--font-display);font-size:1.25rem;font-weight:500;color:var(--color-ink-soft);margin-bottom:var(--space-xl);letter-spacing:.05em;text-transform:uppercase}.preview-title:before,.preview-title:after{content:"—";margin:0 var(--space-md);opacity:.3}.pages-container{display:flex;flex-direction:column;align-items:center;gap:var(--space-2xl)}.footer{text-align:center;padding:var(--space-xl) var(--space-lg);border-top:1px solid var(--color-border);background:var(--color-paper)}.footer p{font-family:var(--font-display);font-size:.9rem;color:var(--color-ink-soft);letter-spacing:.05em}@media(max-width:640px){.header{padding:var(--space-lg) var(--space-md)}.logo-text{font-size:1.5rem}.tagline{font-size:.95rem}.main{padding:var(--space-xl) var(--space-md)}.input-card{padding:var(--space-lg)}.input-label{flex-direction:column;align-items:flex-start;gap:var(--space-xs)}.input-actions{flex-direction:column}.btn{width:100%;justify-content:center}.preview-title:before,.preview-title:after{display:none}}@media print{.header,.input-section,.preview-title,.footer{display:none!important}.main{padding:0;max-width:none}.pages-container{gap:0}.page{page-break-after:always}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-cream: #FDF8F3;--color-paper: #FAF6F1;--color-burgundy: #8B2635;--color-burgundy-light: #A83244;--color-ink: #2C1810;--color-ink-soft: #5C4A42;--color-border: #E8DED6;--color-shadow: rgba(44, 24, 16, .08);--font-display: "Cormorant Garamond", Georgia, serif;--font-ethiopic: "Noto Serif Ethiopic", serif;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-display);background:var(--color-cream);color:var(--color-ink);line-height:1.6;min-height:100vh}body:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");opacity:.03;pointer-events:none;z-index:0}#root{position:relative;z-index:1}::selection{background:var(--color-burgundy);color:var(--color-cream)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-border)}::-webkit-scrollbar-thumb{background:var(--color-ink-soft);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-burgundy)}
