@font-face{font-family:LatinModernMath;src:url(./latinmodern-math-CUFlBgaJ.otf) format("opentype");font-weight:400;font-style:normal}*{font-family:LatinModernMath,sans-serif;box-sizing:border-box}html,body{margin:0;font-family:LatinModernMath,sans-serif;background-color:#d9d9d9}header{display:flex;flex-wrap:nowrap;justify-content:left;align-items:center;gap:30px;height:84vh;background-color:#d9d9d9;padding-left:90px;padding-right:30px;padding-bottom:20px}header>.avatar{vertical-align:middle;width:30%;border-radius:50%;background-color:#ff3e3e;min-width:100px;flex-shrink:0;will-change:transform}header>.avatar:hover{animation:shake .5s;animation-iteration-count:infinite}@keyframes shake{0%{transform:translate(1px,1px) rotate(0)}10%{transform:translate(-1px,-2px) rotate(-1deg)}20%{transform:translate(-3px) rotate(1deg)}30%{transform:translate(3px,2px) rotate(0)}40%{transform:translate(1px,-1px) rotate(1deg)}50%{transform:translate(-1px,2px) rotate(-1deg)}60%{transform:translate(-3px,1px) rotate(0)}70%{transform:translate(3px,1px) rotate(-1deg)}80%{transform:translate(-1px,-1px) rotate(1deg)}90%{transform:translate(1px,2px) rotate(0)}to{transform:translate(1px,-2px) rotate(-1deg)}}header>.text-container>h1{font-size:clamp(2rem,5vw,10vh);margin:0}header>.text-container>p{font-size:clamp(1.5rem,2vw,3vh);margin:0}.avatar{vertical-align:middle;width:30%;border-radius:50%;background-color:#ff3e3e;min-width:100px;flex-shrink:0}@media (max-width: 650px){header{flex-direction:column;justify-content:center;align-items:center;padding-left:30px;padding-right:30px}header>.avatar{width:70%;margin-bottom:20px}header>.text-container>h1{font-size:2rem;text-align:center!important}header>.text-container>p{font-size:1rem;text-align:center!important}}.permission-button{position:fixed;top:45px;left:50%;transform:translate(-50%);padding:10px 20px;background-color:#f99;color:#000;border:none;border-radius:5px;z-index:1000;font-weight:900;font-size:.8rem}.portfolio-notification{position:fixed;top:0;left:0;right:0;z-index:1000;background:#fff;color:#000;border-bottom:1px solid #e0e0e0;animation:slideDown .3s cubic-bezier(.4,0,.2,1)}.notification-content{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;max-width:1400px;margin:0 auto;position:relative}.notification-icon{display:none}.notification-text{font-family:Favorit SSENSE Inter,Helvetica Neue,Arial,sans-serif;font-size:13px;font-weight:400;letter-spacing:.02em;text-transform:uppercase;flex:1;text-align:center}.notification-text a{color:#000;text-decoration:none;border-bottom:1px solid #000000;transition:border-color .2s ease}.notification-text a:hover{border-bottom-color:transparent}.notification-close{background:none;border:none;color:#000;font-size:16px;cursor:pointer;padding:4px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:opacity .2s ease;font-family:Favorit SSENSE Inter,Helvetica Neue,Arial,sans-serif}.notification-close:hover{opacity:.6}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}@media (max-width: 768px){.notification-content{padding:14px 20px}.notification-text{font-size:12px}.notification-close{width:20px;height:20px;font-size:14px}}.dock{position:fixed;bottom:clamp(4px,2vh,20px);left:50%;transform:translate(-50%);display:flex;justify-content:center;align-items:center;gap:clamp(10px,2vw,20px);padding:clamp(8px,1.5vh,12px) clamp(20px,3vw,40px);background-color:#959595;border-radius:clamp(12px,2vw,20px);box-shadow:0 4px 10px #0003;width:fit-content;max-width:90%;transition:all .2s ease;flex-wrap:nowrap;overflow:visible}.dock-button{width:clamp(40px,10vw,70px);height:clamp(40px,10vw,70px);border-radius:clamp(12px,1.5vw,17px);cursor:pointer;transition:transform .2s ease;background-color:transparent;border:none;padding:0;flex-shrink:0;position:relative}.dock-button img{width:100%;height:100%;border-radius:clamp(10px,1.2vw,12px);object-fit:cover}.dock-button:hover{transform:scale(1.1)}.tooltip{visibility:hidden;opacity:0;background-color:gray;color:#fff;text-align:center;padding:clamp(4px,.5vh,5px) clamp(8px,1vw,10px);border-radius:clamp(3px,.5vw,5px);position:absolute;bottom:110%;left:50%;transform:translate(-50%);white-space:nowrap;z-index:1;transition:opacity .3s ease;font-size:clamp(10px,1.2vw,12px)}.dock-button:hover .tooltip{visibility:visible;opacity:1}.notification-badge{position:absolute;top:0;right:0;background-color:#f44035;color:#fff;font-size:clamp(11px,1.3vw,15px);font-weight:700;border-radius:50%;width:clamp(20px,2.8vw,25px);height:clamp(20px,2.8vw,25px);display:flex;align-items:center;justify-content:center;transform:translate(40%,-30%)}.contact-page{background-color:#d9d9d9;display:flex;justify-content:center;align-items:center;min-height:95vh;width:100%;margin:0;padding:20px;box-sizing:border-box}.contact-container{background-color:#c7c7c7;border-radius:20px;padding:60px 50px;max-width:700px;width:100%;text-align:center;box-shadow:0 4px 15px #0000001a;transition:transform .3s ease,box-shadow .3s ease;background-image:url(./ellie-HVrfR-K8.png);background-size:150px;background-repeat:no-repeat;background-position-x:right;background-position-y:bottom;box-sizing:border-box}.contact-container:hover{transform:translateY(-5px);box-shadow:0 8px 25px #0003}.contact-container h1{font-size:2.5rem;color:#000;margin-bottom:40px;font-weight:700;letter-spacing:-.5px;line-height:1.2}.contact-form{display:flex;flex-direction:column;align-items:center;gap:20px;width:100%}.form-input,.form-textarea{width:95%;padding:15px;background-color:#f0f0f0;border:none;border-radius:10px;font-size:1.1rem;color:#555;transition:box-shadow .3s ease;box-sizing:border-box}.form-input:focus,.form-textarea:focus{outline:none;box-shadow:0 0 0 3px #ff3e3e4d}.form-textarea{height:7em;resize:none}.form-submit{background-color:#f5f5f5;color:#4a4a4a;font-size:1.1rem;border:none;border-radius:10px;padding:15px 35px;cursor:pointer;margin-top:30px;transition:transform .2s ease,background-color .2s ease,box-shadow .2s ease;box-shadow:0 3px 7px #0000001a}.form-submit:hover{background-color:#e2e2e2;transform:scale(1.05);box-shadow:0 5px 10px #0003}@media (max-width: 768px){.contact-container{padding:40px 30px;border-radius:15px}.contact-container h1{font-size:2.2rem;margin-bottom:30px}.form-input,.form-textarea{width:100%}}@media (max-width: 500px){.contact-container{padding:30px 20px;border-radius:10px}.contact-container h1{font-size:2rem;margin-bottom:20px}.form-submit{font-size:1rem;padding:12px 30px}}.navbar{display:flex;justify-content:space-between;align-items:center;background-color:#9e9d9d;padding:0 20px;height:40px;position:sticky;top:0;z-index:1000;border-bottom:1px solid #000;gap:10px}.navbar-left{display:flex;align-items:center}.navbar-icon{display:flex;align-items:center;padding-right:15px}.navbar-icon>a>img{width:10px;display:block}.navbar-current{font-family:SFProBold,sans-serif;font-size:16px;color:#000;margin-right:15px;text-decoration:none;font-weight:800}.navbar-link{font-family:SFPro,sans-serif;font-size:16px;color:#000;margin-right:15px;text-decoration:none}.navbar-link:hover{text-decoration:underline}.navbar-clock{font-family:SFPro,sans-serif;font-size:14px;color:#000}.navbar-dropdown{position:relative}.dropdown-menu{display:none;position:absolute;top:100%;left:0;background-color:#dad8d8;border:1px solid #ccc;border-radius:4px;list-style:none;margin:0;padding:5px 0;box-shadow:0 4px 6px #0000001a;z-index:1000}.dropdown-menu.open{display:block}.dropdown-menu li{padding:5px 15px}.dropdown-menu li a{text-decoration:none;font-family:SFPro,sans-serif;font-size:14px;color:#000;white-space:nowrap;display:block}.dropdown-menu li a:hover{background-color:#eae9e9}@media (max-width: 400px){.navbar-current{font-family:SFProBold,sans-serif;font-size:14px;color:#000;margin-right:15px;text-decoration:none;font-weight:800}.navbar-link{font-family:SFPro,sans-serif;font-size:14px;color:#000;margin-right:15px;text-decoration:none}.navbar-clock{font-family:SFPro,sans-serif;font-size:12px;color:#000}}.loader-wrapper{position:fixed;top:0;left:0;width:100%;height:100%;background:#d9d9d9;display:flex;justify-content:center;align-items:center;z-index:9999}.loader{width:40px;aspect-ratio:1;color:#ff3e3e;background:conic-gradient(currentColor 0 270deg,#0000 0);border-radius:50%;animation:l14-0 4s infinite linear}.loader:before{content:"";display:block;height:50%;width:50%;border-top-left-radius:100px;background:currentColor;animation:l14 .5s infinite alternate}@keyframes l14-0{0%,24.99%{transform:rotate(0)}25%,49.99%{transform:rotate(90deg)}50%,74.99%{transform:rotate(180deg)}75%,to{transform:rotate(270deg)}}@keyframes l14{to{transform:translate(-10px,-10px)}}.about-page{background-color:#d9d9d9;display:flex;justify-content:center;align-items:center;min-height:95vh;width:100%;margin:0;padding:20px;box-sizing:border-box}.about-container{background-color:#c7c7c7;border-radius:20px;padding:60px 50px;max-width:850px;width:100%;text-align:center;box-shadow:0 4px 15px #0000001a;transition:transform .3s ease,box-shadow .3s ease;box-sizing:border-box}.about-container:hover{transform:translateY(-5px);box-shadow:0 8px 25px #0003}.title{font-size:2.9rem;font-weight:700;margin:0 0 25px;color:#000;text-align:center;letter-spacing:-.5px;line-height:1.2}.about-description{font-size:1.1rem;line-height:1.8;color:#131313;text-align:justify;padding:0 20px;margin:0 0 30px}.journal-link{text-decoration:none;color:#ff3e3e;font-weight:600;transition:color .3s ease}.journal-link:hover{color:#fe9494}@media (max-width: 768px){.about-container{padding:40px 30px;border-radius:15px}.title{font-size:2.5rem;margin-bottom:20px}.about-description{font-size:1rem;line-height:1.6;padding:0 15px}}@media (max-width: 500px){.about-container{padding:30px 20px;border-radius:10px}.title{font-size:2rem;margin-bottom:15px}.about-description{font-size:.9rem;line-height:1.5;padding:0 10px}}.journal{margin-bottom:20px;padding:15px;border:1px solid #ccc;border-radius:5px}body{background-color:#d9d9d9;margin:0;padding:0}.journal-page{padding:20px;max-width:1200px;margin:0 auto}.journal-title{font-family:SFPro,sans-serif;font-size:2.5em;text-align:center;margin-bottom:20px;color:#000;display:inline-block;position:relative}.journal-title:after{content:"";display:inline-block;width:.11em;height:1.2em;background-color:#000;position:absolute;right:-.2em;top:0;animation:blinking .9s step-end infinite}.loading{font-size:1.5em;color:#666;text-align:center;margin-top:50px}.journal-library{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.journal-preview{background:#0000000b;border:1px solid #ddd;border-radius:8px;box-shadow:0 2px 5px #0000001a;overflow:hidden;transition:transform .2s ease-in-out,box-shadow .2s ease-in-out}.journal-preview:hover{box-shadow:0 4px 10px #00000026}.journal-image{width:100%;height:200px;object-fit:cover}.journal-info{font-family:SFPro,sans-serif;padding:15px}.journal-name{font-family:SFPro,sans-serif;font-size:1.5em;margin:10px 0;color:#333}.journal-date{font-family:SFPro,sans-serif;font-size:.9em;color:#666}.read-more{display:inline-block;margin-top:10px;padding:8px 15px;background:#ff3e3e;color:#fff;text-decoration:none;border-radius:4px;font-weight:700;transition:background .2s ease-in-out}.read-more:hover{background:#fe9494}@keyframes blinking{50%{background-color:transparent}to{background-color:#ff3e3e}}.markdown-container{line-height:1.6;margin:0;background-color:#d9d9d9;color:#333;display:flex;justify-content:center;align-items:flex-start;min-height:100vh;padding:40px 20px}.markdown-content{width:100%;max-width:900px;background-color:#fff;padding:2.5rem;border-radius:12px}.markdown-container h1,.markdown-container h2,.markdown-container h3{color:#000;font-weight:600;margin-top:0}.markdown-container h1{font-size:2.75rem;margin-bottom:1.5rem;line-height:1.2;border-bottom:2px solid #e0e0e0;padding-bottom:.5rem}.markdown-container h2{font-size:2rem;margin-bottom:1rem;margin-top:2rem}.markdown-container h3{font-size:1.5rem;margin-bottom:.75rem;margin-top:1.5rem;visibility:visible;color:#444}.markdown-container p{margin:1.25rem 0;font-size:1.1rem;color:#444}.markdown-container img{max-width:100%;height:auto;border-radius:8px;margin:1.5rem auto;display:block;box-shadow:0 4px 8px #0000000d}.markdown-container code{font-family:Cascadia Mono,Courier New,monospace;background:#f0f0f0;padding:.25rem .5rem;border-radius:4px;font-size:.95rem;color:#d6336c}.markdown-container pre{background:#2d2d2d;padding:1.5rem;border-radius:8px;overflow-x:auto;margin:1.5rem 0;color:#f8f8f2}.markdown-container pre code{color:inherit;background:transparent;padding:0;border-radius:0}.markdown-container blockquote{border-left:4px solid #e0e0e0;padding:.5rem 1rem;margin:1.5rem 0;color:#666;background:#f9f9f9;border-radius:4px}.markdown-container a{color:#007bff;text-decoration:none;font-weight:500}.markdown-container a:hover{text-decoration:underline;color:#0056b3}.markdown-container ul,.markdown-container ol{margin:1.5rem 0;padding-left:1.5rem}.markdown-container li{margin:.5rem 0;color:#444}.markdown-container .journal-detail{max-width:800px;margin:2rem auto;padding:1.5rem;background:#fff;border-radius:8px;box-shadow:0 4px 8px #0000001a}.custom-link a{color:tomato;text-decoration:none;font-weight:700;transition:color .3s ease}.custom-link a:hover{color:#ff4500}@media (max-width: 768px){.markdown-container{padding:20px 10px}.markdown-content{padding:1.5rem}.markdown-container h1{font-size:2rem}.markdown-container h2{font-size:1.75rem}.markdown-container h3{font-size:1.25rem}.markdown-container p{font-size:1rem}}:root{--primary-color: rgb(251, 101, 101);--primary-light: rgb(251, 176, 176);--text-primary: #111827;--text-secondary: #4b5563;--background: #f9fafb;--white: #ffffff}*{margin:0;padding:0;box-sizing:border-box}.app{min-height:100vh;max-width:100vw;background-color:var(--background);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif}.header{background-color:var(--white);box-shadow:0 1px 3px #0000001a;height:100px;display:flex;align-items:center;padding:0 2rem}.header-content{width:100%;max-width:1280px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}.logo{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.logo h1{font-size:1.5rem;color:var(--text-primary);white-space:nowrap}.logo-img{height:40px;width:auto}.icon{color:var(--primary-color);font-size:1.5rem}.icon-small{font-size:1rem;margin-right:.5rem}.install-button{display:flex;align-items:center;padding:.4rem .9rem;background-color:var(--primary-color);color:var(--white);border-radius:.375rem;text-decoration:none;font-weight:500;transition:background-color .2s;white-space:nowrap;flex-shrink:0}.install-button:hover{background-color:var(--primary-light)}.main{max-width:1280px;margin:0 auto;padding:3rem 2rem}.hero{text-align:center;margin-bottom:4rem}.hero h2{font-size:2.5rem;color:var(--text-primary);margin-bottom:1rem}.hero p{font-size:1.25rem;color:var(--text-secondary);max-width:48rem;margin:0 auto}.video-container{margin-bottom:4rem;display:flex;justify-content:center}.video-container iframe{width:100%;max-width:800px;aspect-ratio:16 / 9;border-radius:.5rem;box-shadow:0 4px 6px -1px #0000001a}.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-bottom:4rem}.feature-card{background-color:var(--white);padding:1.5rem;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;text-align:center}.feature-icon{width:3rem;height:3rem;background-color:var(--primary-light);border-radius:.5rem;display:flex;align-items:center;justify-content:center;color:var(--primary-color);margin:0 auto 1rem}.feature-img{width:100%;max-width:200px;margin-bottom:1rem;border-radius:.5rem}.feature-card h3{color:var(--text-primary);margin-bottom:.5rem}.feature-card p{color:var(--text-secondary)}.installation{max-width:48rem;margin:0 auto}.installation h2{text-align:center;font-size:2rem;color:var(--text-primary);margin-bottom:2rem}.steps{display:flex;flex-direction:column;gap:1.5rem}.step{display:flex;gap:1rem}.step-number{width:2rem;height:2rem;background-color:var(--primary-light);color:var(--primary-color);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;flex-shrink:0}.step-content h3{color:var(--text-primary);margin-bottom:.25rem}.step-content p{color:var(--text-secondary)}.footer{border-top:1px solid #e5e7eb;padding:3rem 2rem;text-align:center;color:var(--text-secondary)}a{color:var(--primary-color);text-decoration:none;font-weight:500}a:hover{text-decoration:underline}@media (max-width: 768px){.hero h2{font-size:2rem}.features{grid-template-columns:1fr}.step{flex-direction:column;align-items:center;text-align:center}}@media (max-width: 410px){.logo h1{font-size:1rem}.install-button{padding:.25rem .5rem;font-size:.75rem}}.mini-game-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a1a,#2d2d2d);color:#fff;padding:2rem}.game-title{font-size:2.5rem;margin-bottom:2rem;text-transform:uppercase;letter-spacing:3px;text-shadow:0 0 10px rgba(255,255,255,.5);animation:glow 2s ease-in-out infinite alternate}.instructions{font-size:1.2rem;margin-bottom:3rem;color:#b3b3b3}.piano-keys{display:flex;gap:.5rem;margin-top:2rem}.key{width:60px;height:200px;background:#fff;border:2px solid #333;border-radius:0 0 5px 5px;cursor:pointer;transition:all .1s ease;display:flex;align-items:flex-end;justify-content:center;padding-bottom:1rem;font-weight:700;color:#333}.key:hover{background:#f0f0f0}.key.active{background:#e0e0e0;transform:translateY(5px);box-shadow:0 0 20px #ffffff4d}.note-display{margin-top:2rem;font-size:1.5rem;min-height:2rem;padding:1rem 2rem;background:#ffffff1a;border-radius:10px;animation:fadeIn .3s ease-out}@keyframes glow{0%{text-shadow:0 0 5px rgba(255,255,255,.5)}to{text-shadow:0 0 20px rgba(255,255,255,.8)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.piano-keys{flex-wrap:wrap;justify-content:center}.key{width:45px;height:150px}.game-title{font-size:2rem}.instructions{font-size:1rem;text-align:center}}
