:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;overflow:hidden}#root{width:100%;height:100%}.App{width:100vw;height:100vh;overflow:hidden;position:relative;background:#0b0212}canvas{display:block;width:100%;height:100%;position:relative;z-index:1;background:transparent}.background-overlay{position:absolute;inset:0;z-index:2;transition:opacity .2s linear;pointer-events:none;display:flex;align-items:flex-start;padding-top:2rem;color:#fff;text-shadow:0 4px 12px rgba(0,0,0,.35)}.typed-text{font-family:Courier New,Courier,monospace;font-size:clamp(2rem,4vw,3rem);font-weight:600;letter-spacing:.12em;position:relative;display:inline-flex;flex-direction:column;gap:.35rem}.typed-cursor{display:inline-block;width:.1em;margin-left:.15em}.typed-line{display:block;min-height:1.25em}.space-hint{margin-top:1.5rem;font-family:Courier New,Courier,monospace;font-size:.85rem;letter-spacing:.28em;text-transform:uppercase;opacity:.65}.hint-overlay{position:absolute;bottom:4rem;left:50%;transform:translate(-50%);white-space:nowrap;font-family:Courier New,Courier,monospace;letter-spacing:.28em;text-transform:uppercase;color:#fff2e4e6;opacity:.85;pointer-events:none;z-index:3}.scroll-btn{position:absolute;bottom:4rem;left:50%;transform:translate(-50%);z-index:4;font-family:Georgia,Times New Roman,serif;font-size:1rem;letter-spacing:.05em;padding:.7em 1.8em;background:linear-gradient(135deg,#d4a853,#c4923a,#d4a853);color:#2a1a0a;border:2px solid #b8862d;border-radius:4px;cursor:pointer;box-shadow:0 2px 12px #b4822866;transition:transform .2s,box-shadow .2s}.scroll-btn:hover{transform:translate(-50%) scale(1.05);box-shadow:0 4px 20px #b4822899}.scroll-overlay{position:absolute;inset:0;z-index:10;display:flex;align-items:center;justify-content:center;background:#000000a6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:fadeIn .4s ease}.scroll-parchment{position:relative;max-width:920px;width:92%;padding:2.2rem 2.5rem;background:radial-gradient(ellipse at 30% 20%,rgba(245,230,200,.5),transparent 60%),radial-gradient(ellipse at 70% 80%,rgba(200,170,120,.3),transparent 60%),linear-gradient(135deg,#f5e6c8,#eedcb3 20%,#e8d0a0,#eedcb3 80%,#f5e6c8);border:2px solid #b8862d;border-radius:4px;box-shadow:0 0 60px #00000080,0 0 15px #b4822833,inset 0 0 60px #8b5a1e1f;color:#3a2510;font-family:Georgia,Times New Roman,serif;line-height:1.65;animation:scrollUnfurl .6s cubic-bezier(.16,1,.3,1)}.scroll-close{position:absolute;top:.6rem;right:.8rem;background:none;border:none;font-size:1.2rem;color:#b8862d;cursor:pointer;padding:.2em .5em;font-family:Georgia,serif;transition:color .2s}.scroll-close:hover{color:#3a2510}.scroll-header{text-align:center;font-size:1.35rem;font-weight:700;color:#6b3a0a;margin-bottom:.6rem;letter-spacing:.06em}.scroll-fact{text-align:center;font-size:.95rem;margin-bottom:1.2rem;color:#4a2a0a;line-height:1.6}.scroll-fact strong{color:#8b4513}.scroll-body{display:flex;gap:2rem;align-items:flex-start}.scroll-col{flex:1;min-width:0}.scroll-divider-v{width:1px;align-self:stretch;background:linear-gradient(to bottom,transparent,#c4923a 20%,#c4923a 80%,transparent)}.scroll-attribution{text-align:center;font-size:.85rem;color:#7a5020;margin-bottom:.8rem}.scroll-poem{text-align:center;font-style:italic}.scroll-poem p{margin:.15rem 0;font-size:.9rem;line-height:1.55}.scroll-stanza-break{height:.6rem}.scroll-rtl{direction:rtl;font-family:Traditional Arabic,Geeza Pro,Georgia,serif}.scroll-rtl p{font-size:1rem;font-style:normal}.scroll-lang-label{text-align:center;font-size:.75rem;font-weight:700;color:#b8862d;margin-bottom:.4rem;margin-top:1rem;letter-spacing:.15em;text-transform:uppercase}.scroll-lang-label:first-child{margin-top:0}@media(max-height:500px){.background-overlay{padding-top:.5rem}.typed-text{font-size:clamp(.9rem,2.5vw,1.4rem);gap:.15rem}.typed-line{min-height:1em}.hint-overlay{bottom:2.5rem;font-size:.6rem}.scroll-btn{bottom:2.5rem;font-size:.75rem;padding:.4em 1em}.scroll-parchment{max-height:92vh;overflow-y:auto;padding:1rem 1.5rem}.scroll-header{font-size:1rem;margin-bottom:.3rem}.scroll-fact{font-size:.8rem;margin-bottom:.6rem}.scroll-body{gap:1.5rem}.scroll-poem p{font-size:.8rem;margin:.1rem 0}.scroll-stanza-break{height:.3rem}.scroll-attribution{font-size:.75rem;margin-bottom:.4rem}.scroll-lang-label{margin-top:.5rem;margin-bottom:.2rem;font-size:.65rem}.scroll-rtl p{font-size:.85rem}}@media(max-width:768px){.hint-overlay{font-size:.7rem;letter-spacing:.15em;bottom:3rem}.scroll-btn{font-size:.85rem;padding:.6em 1.2em;bottom:3rem}.scroll-parchment{width:94%;padding:1.5rem 1.2rem;max-height:90vh;overflow-y:auto}.scroll-header{font-size:1.1rem}.scroll-fact{font-size:.85rem}.scroll-body{flex-direction:column;gap:1rem;align-items:center}.scroll-divider-v{width:100%;height:1px;align-self:auto;background:linear-gradient(to right,transparent,#c4923a 20%,#c4923a 80%,transparent)}.scroll-poem p{font-size:.85rem}.scroll-rtl p{font-size:.9rem}.scroll-attribution{font-size:.8rem}.scroll-col{display:flex;flex-direction:column;align-items:center;width:100%}.scroll-poem{width:100%}.scroll-rtl{text-align:center;direction:ltr}.scroll-lang-label{text-align:center}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scrollUnfurl{0%{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}
