@import url(https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700;900&family=Cinzel+Decorative:wght@400;700&family=IM+Fell+English:ital@0;1&family=Lato:wght@300;400;700&display=swap);*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--hp-gold:#c9a227;--hp-gold-light:#f0d060;--hp-dark:#0d0a1a;--hp-maroon:#740001;--hp-crimson:#ae0001;--hp-parchment:#f5e6c8;--hp-cream:#ede0c4;--hp-purple:#1a0a2e;--hp-navy:#0f1b35;--hp-muted:#a89060;--font-heading:"Cinzel Decorative",serif;--font-title:"Cinzel",serif;--font-body:"IM Fell English",serif;--font-sans:"Lato",sans-serif}html{scroll-behavior:smooth}body{background-color:#0d0a1a;color:#f5e6c8;color:var(--hp-parchment);font-family:"IM Fell English",serif;font-family:var(--font-body);-webkit-font-smoothing:antialiased;width:100%;font-size:18px}code{font-family:"Courier New",monospace}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#0d0a1a;background:var(--hp-dark)}::-webkit-scrollbar-thumb{background:#c9a227;background:var(--hp-gold);border-radius:3px}@-webkit-keyframes twinkle{0%,to{opacity:.2;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}@keyframes twinkle{0%,to{opacity:.2;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}@-webkit-keyframes float{0%,to{transform:translateY(0) rotate(0deg)}33%{transform:translateY(-14px) rotate(2deg)}66%{transform:translateY(-7px) rotate(-2deg)}}@keyframes float{0%,to{transform:translateY(0) rotate(0deg)}33%{transform:translateY(-14px) rotate(2deg)}66%{transform:translateY(-7px) rotate(-2deg)}}@-webkit-keyframes glow-pulse{0%,to{text-shadow:0 0 10px #c9a227,0 0 20px #c9a227;text-shadow:0 0 10px var(--hp-gold),0 0 20px var(--hp-gold)}50%{text-shadow:0 0 22px #f0d060,0 0 44px #f0d060,0 0 66px #c9a227;text-shadow:0 0 22px var(--hp-gold-light),0 0 44px var(--hp-gold-light),0 0 66px var(--hp-gold)}}@keyframes glow-pulse{0%,to{text-shadow:0 0 10px #c9a227,0 0 20px #c9a227;text-shadow:0 0 10px var(--hp-gold),0 0 20px var(--hp-gold)}50%{text-shadow:0 0 22px #f0d060,0 0 44px #f0d060,0 0 66px #c9a227;text-shadow:0 0 22px var(--hp-gold-light),0 0 44px var(--hp-gold-light),0 0 66px var(--hp-gold)}}@-webkit-keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}@-webkit-keyframes fadeInUp{0%{opacity:0;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}@-webkit-keyframes particleDrift{0%{transform:translateY(0) rotate(0deg);opacity:0}10%{opacity:.8}90%{opacity:.8}to{transform:translateY(-100px) rotate(1turn);opacity:0}}@keyframes particleDrift{0%{transform:translateY(0) rotate(0deg);opacity:0}10%{opacity:.8}90%{opacity:.8}to{transform:translateY(-100px) rotate(1turn);opacity:0}}@-webkit-keyframes borderGlow{0%,to{box-shadow:0 0 6px rgba(201,162,39,.3)}50%{box-shadow:0 0 18px rgba(201,162,39,.6),0 0 30px rgba(201,162,39,.3)}}@keyframes borderGlow{0%,to{box-shadow:0 0 6px rgba(201,162,39,.3)}50%{box-shadow:0 0 18px rgba(201,162,39,.6),0 0 30px rgba(201,162,39,.3)}}.gold-shimmer{background:linear-gradient(90deg,#c9a227,#f0d060 40%,#fff8dc 50%,#f0d060 60%,#c9a227);background:linear-gradient(90deg,var(--hp-gold),var(--hp-gold-light) 40%,#fff8dc 50%,var(--hp-gold-light) 60%,var(--hp-gold));background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;-webkit-animation:shimmer 4s linear infinite;animation:shimmer 4s linear infinite}.chapter-label{font-family:"Cinzel",serif;font-family:var(--font-title);font-size:.65rem;letter-spacing:.35em;text-transform:uppercase;opacity:.75;display:block;margin-bottom:8px}.chapter-label,.ornament{color:#c9a227;color:var(--hp-gold)}.ornament{display:flex;align-items:center;grid-gap:12px;gap:12px;justify-content:center;opacity:.45;font-size:1rem}.ornament:after,.ornament:before{content:"";flex:1 1;height:1px;max-width:180px;background:linear-gradient(90deg,transparent,#c9a227);background:linear-gradient(90deg,transparent,var(--hp-gold))}.ornament:after{background:linear-gradient(270deg,transparent,#c9a227);background:linear-gradient(270deg,transparent,var(--hp-gold))}.parchment-card{background:linear-gradient(135deg,rgba(245,230,200,.05),rgba(201,162,39,.03));border:1px solid rgba(201,162,39,.18);border-radius:4px}.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}.reveal.visible{opacity:1;transform:translateY(0)}body{color:var(--hp-parchment)!important;overflow-x:hidden}.main,body{background-color:var(--hp-dark)}.main{min-height:100vh;position:relative}.loadingclass{position:fixed;inset:0;background:var(--hp-dark);display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:9000}.hidespinner{opacity:0;pointer-events:none;transform:translateY(-100%);transition:all 1.5s ease-in-out}.hp-btn{font-family:var(--font-title);font-size:.75rem;letter-spacing:.15em;padding:12px 28px;border:1px solid var(--hp-gold);color:var(--hp-gold);background:transparent;cursor:pointer;text-decoration:none;display:inline-block;transition:all .3s ease;position:relative;overflow:hidden}.hp-btn:before{content:"";position:absolute;inset:0;background:var(--hp-gold);transform:scaleX(0);transform-origin:left;transition:transform .3s ease;z-index:-1}.hp-btn:hover{color:var(--hp-dark);text-decoration:none}.hp-btn:hover:before{transform:scaleX(1)}.hp-btn-solid{background:var(--hp-gold);color:var(--hp-dark)!important;font-weight:700}.hp-btn-solid:hover{background:var(--hp-gold-light)}.section-heading{font-family:var(--font-heading);font-size:clamp(1.5rem,4vw,2.3rem);color:var(--hp-gold);text-align:center;margin-bottom:8px}.timeline{position:relative;padding-left:32px}.timeline:before{content:"";position:absolute;left:8px;top:0;bottom:0;width:1px;background:linear-gradient(180deg,transparent,var(--hp-gold) 30%,var(--hp-gold) 70%,transparent)}.timeline-item{position:relative;margin-bottom:40px}.timeline-item:before{content:"✦";position:absolute;left:-28px;top:4px;color:var(--hp-gold);font-size:.7rem}.skill-badge{font-family:var(--font-sans);font-size:.72rem;padding:5px 12px;border:1px solid rgba(201,162,39,.35);border-radius:2px;color:var(--hp-cream);background:rgba(201,162,39,.06);display:inline-block;transition:all .25s ease;margin:4px}.skill-badge:hover{border-color:var(--hp-gold);background:rgba(201,162,39,.15);color:var(--hp-gold)}.project-card{background:linear-gradient(160deg,rgba(26,10,46,.9),rgba(15,27,53,.9));border:1px solid rgba(201,162,39,.2);border-radius:6px;padding:28px 24px;transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;height:100%}.project-card:hover{transform:translateY(-6px);box-shadow:0 16px 40px rgba(0,0,0,.4),0 0 20px rgba(201,162,39,.1);border-color:rgba(201,162,39,.5)}.hp-container{max-width:1100px;margin:0 auto;padding:0 28px}.hp-section{padding:96px 0}@media (max-width:768px){.hp-section{padding:64px 0}.hp-container{padding:0 18px}}.hp-nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:20px 0;transition:all .4s ease}.hp-nav--scrolled{background:rgba(13,10,26,.96);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);padding:12px 0;border-bottom:1px solid rgba(201,162,39,.15);box-shadow:0 4px 30px rgba(0,0,0,.4)}.hp-nav__inner{max-width:1100px;margin:0 auto;padding:0 28px;justify-content:space-between}.hp-nav__brand,.hp-nav__inner{display:flex;align-items:center}.hp-nav__brand{background:none;border:none;cursor:pointer;grid-gap:10px;gap:10px;padding:0}.hp-nav__crest{color:var(--hp-gold);font-size:1.2rem;-webkit-animation:glow-pulse 3s ease-in-out infinite;animation:glow-pulse 3s ease-in-out infinite}.hp-nav__name{font-family:var(--font-title);font-size:1rem;color:var(--hp-parchment);letter-spacing:.08em}.hp-nav__links{list-style:none;display:flex;align-items:center;grid-gap:6px;gap:6px;margin:0;padding:0}.hp-nav__link{background:none;border:none;cursor:pointer;font-family:var(--font-title);font-size:.66rem;letter-spacing:.12em;color:rgba(245,230,200,.7);padding:6px 10px;transition:color .25s ease;text-transform:uppercase}.hp-nav__link:hover{color:var(--hp-gold)}.hp-nav__burger{display:none;flex-direction:column;grid-gap:5px;gap:5px;background:none;border:none;cursor:pointer;padding:4px}.hp-nav__burger span{display:block;width:24px;height:1.5px;background:var(--hp-gold);transition:all .3s ease;transform-origin:center}.hp-nav__burger.is-open span:first-child{transform:rotate(45deg) translate(4px,4px)}.hp-nav__burger.is-open span:nth-child(2){opacity:0}.hp-nav__burger.is-open span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}.hp-nav__drawer{display:none;flex-direction:column;padding:0 28px;background:rgba(13,10,26,.98);border-top:1px solid rgba(201,162,39,.15);max-height:0;overflow:hidden;visibility:hidden;transition:max-height .4s ease,padding .4s ease,visibility 0s .4s}.hp-nav__drawer.is-open{max-height:420px;padding:16px 28px 24px;visibility:visible;transition:max-height .4s ease,padding .4s ease,visibility 0s}.hp-nav__drawer-link{background:none;cursor:pointer;font-family:var(--font-title);font-size:.8rem;letter-spacing:.1em;color:rgba(245,230,200,.8);padding:14px 0;text-align:left;border:none;border-bottom:1px solid rgba(201,162,39,.1);transition:color .2s ease}.hp-nav__drawer-link:hover,.hp-nav__resume{color:var(--hp-gold)}.hp-nav__resume{display:inline-flex;align-items:center;grid-gap:6px;gap:6px;font-family:var(--font-title);font-size:.7rem;letter-spacing:.12em;padding:9px 18px;border:1px solid var(--hp-gold);background:rgba(201,162,39,.08);text-decoration:none;border-radius:2px;transition:all .3s ease;position:relative;overflow:hidden;white-space:nowrap}.hp-nav__resume:before{content:"";position:absolute;inset:0;background:var(--hp-gold);transform:scaleX(0);transform-origin:left;transition:transform .3s ease;z-index:-1}.hp-nav__resume:hover{color:var(--hp-dark);text-decoration:none;box-shadow:0 0 14px rgba(201,162,39,.35)}.hp-nav__resume:hover:before{transform:scaleX(1)}.hp-nav__resume-icon{font-size:.85rem}.hp-nav__drawer-resume{text-decoration:none;color:var(--hp-gold)!important;margin-top:8px;border:1px solid rgba(201,162,39,.3);padding:12px 14px;border-radius:2px;background:rgba(201,162,39,.06);text-align:center}@media (max-width:820px){.hp-nav__links{display:none}.hp-nav__burger,.hp-nav__drawer{display:flex}}.hp-home{position:relative;overflow-x:hidden}.hp-float-deco{-webkit-animation:float 5s ease-in-out infinite;animation:float 5s ease-in-out infinite;pointer-events:none;z-index:0}.deco-hallows{-webkit-animation-duration:7s;animation-duration:7s;-webkit-animation-delay:0s;animation-delay:0s}.deco-snitch{-webkit-animation-duration:3.5s;animation-duration:3.5s;-webkit-animation-delay:1s;animation-delay:1s}.deco-broom{-webkit-animation-duration:6s;animation-duration:6s;-webkit-animation-delay:.5s;animation-delay:.5s}.deco-stone{-webkit-animation-duration:4.5s;animation-duration:4.5s;-webkit-animation-delay:1.5s;animation-delay:1.5s}.spark-container{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:0}.spark{position:absolute;bottom:0;width:3px;height:3px;border-radius:50%;background:var(--hp-gold);box-shadow:0 0 6px 2px rgba(201,162,39,.7);-webkit-animation:sparkRise linear infinite;animation:sparkRise linear infinite}@-webkit-keyframes sparkRise{0%{transform:translateY(0) scale(1);opacity:0;bottom:0}10%{opacity:1}80%{opacity:.6}to{transform:translateY(-60vh) scale(.3);opacity:0}}@keyframes sparkRise{0%{transform:translateY(0) scale(1);opacity:0;bottom:0}10%{opacity:1}80%{opacity:.6}to{transform:translateY(-60vh) scale(.3);opacity:0}}.exp-badge{font-family:var(--font-title);font-size:.6rem;letter-spacing:.12em;padding:4px 10px;border:1px solid rgba(201,162,39,.4);color:var(--hp-gold);border-radius:2px;white-space:nowrap;background:rgba(201,162,39,.06);flex-shrink:0}.contact-owl{font-size:3rem;margin-bottom:20px;display:block;-webkit-animation:float 3s ease-in-out infinite;animation:float 3s ease-in-out infinite;-webkit-filter:drop-shadow(0 4px 12px rgba(201,162,39,.4));filter:drop-shadow(0 4px 12px rgba(201,162,39,.4))}.starfield{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}.star-dot{position:absolute;background:#f0d060;border-radius:50%;-webkit-animation:twinkle 3s ease-in-out infinite;animation:twinkle 3s ease-in-out infinite;opacity:.3}.hp-hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:120px 0 80px;position:relative;z-index:1;background:radial-gradient(ellipse at 50% 60%,rgba(116,0,1,.12) 0,transparent 70%),radial-gradient(ellipse at 80% 20%,rgba(26,10,46,.3) 0,transparent 60%)}.hp-hero:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center bottom,rgba(201,162,39,.04) 0,transparent 70%);pointer-events:none}.hp-hero__inner{max-width:720px;margin:0 auto;padding:0 24px;position:relative;z-index:1}.hp-hero__wand{display:inline-block;margin-bottom:24px;-webkit-animation:float 4s ease-in-out infinite;animation:float 4s ease-in-out infinite;-webkit-filter:drop-shadow(0 0 8px rgba(201,162,39,.5));filter:drop-shadow(0 0 8px rgba(201,162,39,.5))}.hp-hero__name{font-family:var(--font-heading);font-size:clamp(2.4rem,8vw,5rem);line-height:1.1;margin:12px 0 20px;letter-spacing:-.01em}.hp-hero__typewriter{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;grid-gap:6px;gap:6px;font-family:var(--font-body);font-size:clamp(.95rem,2.5vw,1.25rem);font-style:italic;margin-bottom:28px;min-height:2rem}.typewriter-text{font-style:normal;font-family:var(--font-title);font-size:.9em}.typewriter-cursor,.typewriter-text{color:var(--hp-gold)}.hp-hero__bio{font-family:var(--font-body);font-size:1rem;color:rgba(245,230,200,.72);max-width:480px;margin:0 auto 36px;line-height:1.7}.hp-hero__cta{grid-gap:14px;gap:14px;margin-bottom:48px}.hp-hero__badges,.hp-hero__cta{display:flex;justify-content:center;flex-wrap:wrap}.hp-hero__badges{grid-gap:12px;gap:12px;margin-top:8px}.hp-hero__badge{display:flex;align-items:center;grid-gap:7px;gap:7px;padding:7px 14px;border:1px solid rgba(201,162,39,.25);border-radius:2px;background:rgba(201,162,39,.05);-webkit-animation:fadeInUp .8s ease both;animation:fadeInUp .8s ease both;transition:border-color .25s ease}.hp-hero__badge:hover{border-color:rgba(201,162,39,.55)}.hp-hero__scroll-hint{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;grid-gap:6px;gap:6px;opacity:.35;font-family:var(--font-title);font-size:.55rem;letter-spacing:.25em;color:var(--hp-gold);-webkit-animation:fadeInUp 1.5s ease 2s both;animation:fadeInUp 1.5s ease 2s both}.scroll-arrow{width:1px;height:28px;background:linear-gradient(180deg,var(--hp-gold),transparent);-webkit-animation:float 2s ease-in-out infinite;animation:float 2s ease-in-out infinite}.hp-about__card{display:grid;grid-template-columns:1fr 300px;grid-gap:36px;gap:36px;padding:36px}.hp-about__text{display:flex;flex-direction:column;grid-gap:16px;gap:16px}.hp-about__text p{font-family:var(--font-body);font-size:.98rem;color:rgba(245,230,200,.82);line-height:1.75}.hp-about__details{display:flex;flex-direction:column;grid-gap:16px;gap:16px;border-left:1px solid rgba(201,162,39,.2);padding-left:28px}.hp-detail-item{display:flex;flex-direction:column;grid-gap:4px;gap:4px}.hp-detail-label{font-family:var(--font-title);font-size:.58rem;letter-spacing:.2em;color:var(--hp-gold);text-transform:uppercase}.hp-detail-item>:last-child{font-family:var(--font-sans);font-size:.82rem;color:rgba(245,230,200,.75)}.hp-link{color:var(--hp-gold);text-decoration:none;border-bottom:1px solid rgba(201,162,39,.3);transition:border-color .2s ease}.hp-link:hover{border-color:var(--hp-gold)}.hp-skills{position:relative;z-index:1}.hp-achievements__grid,.hp-skills{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:20px;gap:20px}.hp-achievement-card{padding:24px 20px;text-align:center;transition:border-color .3s ease,box-shadow .3s ease}.hp-achievement-card:hover{border-color:rgba(201,162,39,.45);box-shadow:0 8px 24px rgba(0,0,0,.3),0 0 12px rgba(201,162,39,.08)}.hp-projects{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:20px;gap:20px}.hp-contact,.hp-projects{position:relative;z-index:1}.hp-contact{max-width:600px;margin:0 auto}.hp-contact__card{padding:44px 40px;text-align:center;display:flex;flex-direction:column;align-items:center}.hp-contact__message{font-family:var(--font-body);font-size:1rem;color:rgba(245,230,200,.8);line-height:1.75;margin-bottom:28px;font-style:italic}.hp-contact__links{display:flex;flex-wrap:wrap;grid-gap:12px;gap:12px;justify-content:center}.hp-contact__link{display:flex;align-items:center;grid-gap:7px;gap:7px;font-family:var(--font-title);font-size:.7rem;letter-spacing:.12em;color:rgba(245,230,200,.6);text-decoration:none;padding:8px 16px;border:1px solid rgba(201,162,39,.2);border-radius:2px;transition:all .25s ease}.hp-contact__link:hover{color:var(--hp-gold);border-color:rgba(201,162,39,.5);background:rgba(201,162,39,.06)}.hp-footer{padding:40px 0 32px;border-top:1px solid rgba(201,162,39,.1)}.hp-footer,.hp-section{position:relative;z-index:1}@media (max-width:960px){.hp-achievements__grid,.hp-projects,.hp-skills{grid-template-columns:1fr 1fr}.hp-about__card{grid-template-columns:1fr}.hp-about__details{border-left:none;padding-left:0;border-top:1px solid rgba(201,162,39,.2);padding-top:20px}}@media (max-width:640px){.hp-achievements__grid,.hp-projects,.hp-skills{grid-template-columns:1fr}.hp-hero__cta{flex-direction:column;align-items:center}.hp-contact__card{padding:28px 20px}}.letter-envelope{max-width:780px;margin:0 auto;background:linear-gradient(135deg,#f5e6c8,#ede0c0 40%,#f0d8a8);border:1px solid rgba(139,100,20,.45);border-radius:3px;box-shadow:0 20px 60px rgba(0,0,0,.55),inset 0 0 80px rgba(201,162,39,.04);overflow:visible;position:relative}.letter-flap-wrap{position:absolute;top:0;left:0;right:0;height:130px;perspective:700px;perspective-origin:top;z-index:8;pointer-events:none;overflow:hidden}.letter-flap{width:100%;height:100%;transform-origin:top center;transform-style:preserve-3d;transition:transform .1s ease-out}.letter-flap__face{position:absolute;inset:0;-webkit-clip-path:polygon(0 0,100% 0,50% 100%);clip-path:polygon(0 0,100% 0,50% 100%);backface-visibility:hidden;-webkit-backface-visibility:hidden}.letter-flap__face--front{background:linear-gradient(170deg,#f5e4c0,#e8cfaa);border-bottom:1.5px solid rgba(139,100,20,.35)}.letter-flap__face--back{background:linear-gradient(170deg,#e0ccaa,#d4bc90);transform:rotateX(180deg)}.letter-envelope:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(transparent,transparent 28px,rgba(139,100,20,.06) 0,rgba(139,100,20,.06) 29px);pointer-events:none;z-index:0}.letter-sealed{display:flex;flex-direction:column;align-items:center;justify-content:center;grid-gap:7px;gap:7px;padding:32px 40px 36px;position:absolute;inset:0;z-index:2;background:linear-gradient(135deg,#f5e6c8,#ede0c0 40%,#f0d8a8);transition:opacity .12s ease;border-radius:3px}.letter-fold-line{position:absolute;background:rgba(139,100,20,.11);pointer-events:none}.letter-fold-line--h{left:0;right:0;top:33%;height:1px}.letter-fold-line--v{top:0;bottom:0;left:50%;width:1px}.letter-sealed__school{font-family:var(--font-title);font-size:.72rem;letter-spacing:.14em;color:#3a1e00;text-align:center;margin:0}.letter-sealed__to{font-family:var(--font-body);font-size:.96rem;color:#5a3a10;font-style:italic;margin:0}.letter-sealed__hint{font-family:var(--font-title);font-size:.62rem;letter-spacing:.2em;color:rgba(90,58,16,.45);text-transform:uppercase;margin:2px 0 0}.letter-wax-seal{position:relative;width:72px;height:72px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.letter-wax-seal:before{content:"";position:absolute;inset:0;border-radius:50%;background:radial-gradient(circle at 38% 35%,#e05555,#8b0000 60%);box-shadow:0 3px 14px rgba(100,0,0,.55),inset 0 1px 3px rgba(255,150,150,.22)}.letter-wax-seal__ring{position:absolute;inset:-5px;border-radius:50%;border:1.5px solid rgba(160,0,0,.32)}.letter-wax-seal__h{position:relative;z-index:1;font-family:var(--font-heading);font-size:1.75rem;color:rgba(255,215,160,.9);font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.4);line-height:1}.letter-wax-seal--lg{width:72px;height:72px}.letter-wax-seal--lg .letter-wax-seal__h{font-size:1.9rem}.letter-inner{padding:24px 28px 28px;position:relative;z-index:1;transition:opacity .12s ease,transform .12s ease}.letter-inner__header{display:flex;align-items:center;grid-gap:14px;gap:14px;margin-bottom:10px}.letter-cols{display:grid;grid-template-columns:1fr 210px;grid-gap:24px;gap:24px;margin-top:14px}.letter-col-right{border-left:1px solid rgba(139,100,20,.2);padding-left:20px;display:flex;flex-direction:column;grid-gap:10px;gap:10px}.letter-col-right__seal{display:flex;justify-content:center;margin-top:auto;padding-top:12px}.letter-header{text-align:center;padding:0 36px 16px;border-bottom:1px solid rgba(139,100,20,.25);margin-bottom:20px}.letter-school{font-family:var(--font-title);font-size:.88rem;letter-spacing:.18em;color:#3a1e00;margin-bottom:6px;font-weight:700}.letter-headmaster{font-family:var(--font-body);font-size:.8rem;color:#5a3a10;font-style:italic;line-height:1.55}.letter-divider{width:120px;height:1px;background:linear-gradient(90deg,transparent,rgba(139,100,20,.4),transparent);margin:12px auto 0}.letter-body{padding:0 40px 36px;position:relative;z-index:1}.letter-salutation{font-size:1.08rem;color:#2a1200;font-weight:600;font-style:italic}.letter-para,.letter-salutation{font-family:var(--font-body);margin-bottom:14px}.letter-para{font-size:1rem;color:#2e1800;line-height:1.82;text-align:justify}.letter-details{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:10px 28px;gap:10px 28px;margin:20px 0;padding:16px 20px;background:rgba(139,100,20,.07);border:1px solid rgba(139,100,20,.2);border-radius:2px}.letter-detail-item{display:flex;flex-direction:column;grid-gap:2px;gap:2px}.letter-detail-label{font-family:var(--font-title);font-size:.68rem;letter-spacing:.18em;color:#7a4a00;text-transform:uppercase}.letter-detail-value{font-size:.95rem}.letter-closing,.letter-detail-value{font-family:var(--font-body);color:#2e1800}.letter-closing{margin-top:20px;font-size:.96rem;line-height:1.82}.letter-signature{font-family:var(--font-heading);font-size:1.35rem;color:#3a1e00;margin-top:8px;letter-spacing:.04em}.frog-cards-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:28px;gap:28px;position:relative;z-index:1}.frog-card{height:320px;perspective:900px;cursor:pointer}.frog-card__inner{width:100%;height:100%;position:relative;transform-style:preserve-3d;transition:transform .65s cubic-bezier(.4,.2,.2,1)}.frog-card:hover .frog-card__inner{transform:rotateY(180deg)}.frog-card__back,.frog-card__front{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:4px;overflow:hidden}.frog-card__front{background:linear-gradient(160deg,rgba(26,10,46,.95),rgba(13,10,26,.98));border:1px solid rgba(201,162,39,.35);box-shadow:0 8px 32px rgba(0,0,0,.5),inset 0 0 60px rgba(201,162,39,.03)}.frog-card__back{background:linear-gradient(160deg,#f5e6c8,#ede0c0);border:1px solid rgba(139,100,20,.4);box-shadow:0 8px 32px rgba(0,0,0,.5);transform:rotateY(180deg)}.frog-card__frame{height:100%;padding:18px 16px 14px;display:flex;flex-direction:column;align-items:center;position:relative;outline:1px solid rgba(201,162,39,.12);outline-offset:-6px}.frog-card__frame--back{align-items:flex-start;outline:1px solid rgba(139,100,20,.18)}.frog-card__top{width:100%;display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.frog-card__num{letter-spacing:.15em;color:rgba(201,162,39,.6)}.frog-card__num,.frog-card__rarity{font-family:var(--font-title);font-size:.58rem}.frog-card__rarity{letter-spacing:.1em}.frog-card__icon{font-size:3.2rem;margin:12px 0 10px;-webkit-filter:drop-shadow(0 0 12px rgba(201,162,39,.45));filter:drop-shadow(0 0 12px rgba(201,162,39,.45));flex:1 1;display:flex;align-items:center}.frog-card__title{font-family:var(--font-title);font-size:.78rem;letter-spacing:.1em;color:var(--hp-parchment);text-align:center;margin-bottom:10px}.frog-card__tags{display:flex;flex-wrap:wrap;grid-gap:5px;gap:5px;justify-content:center;margin-bottom:10px}.frog-card__tag{font-family:var(--font-title);font-size:.55rem;letter-spacing:.1em;padding:3px 8px;border:1px solid rgba(201,162,39,.3);color:rgba(201,162,39,.75);border-radius:2px}.frog-card__hint{font-family:var(--font-body);font-size:.6rem;color:rgba(201,162,39,.3);font-style:italic;letter-spacing:.05em;margin-top:auto}.frog-card__back-title{font-family:var(--font-title);font-size:.82rem;letter-spacing:.1em;color:#3a1e00;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid rgba(139,100,20,.25);width:100%}.frog-card__desc{font-family:var(--font-body);font-size:.82rem;color:#2e1800;line-height:1.7;flex:1 1}.frog-card__link{display:inline-flex;align-items:center;grid-gap:6px;gap:6px;font-family:var(--font-title);font-size:.65rem;letter-spacing:.12em;color:#7a4a00;text-decoration:none;padding:8px 14px;border:1px solid rgba(139,100,20,.4);border-radius:2px;margin-top:16px;transition:all .25s ease;background:rgba(139,100,20,.08)}.frog-card__link:hover{background:rgba(139,100,20,.18);border-color:rgba(139,100,20,.7);color:#3a1e00;text-decoration:none}.hp-houses{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:24px;gap:24px;position:relative;z-index:1}.house-card{background:linear-gradient(145deg,rgba(26,10,46,.5),rgba(13,10,26,.7));background:linear-gradient(145deg,var(--house-bg,rgba(26,10,46,.5)),rgba(13,10,26,.7));border:1px solid rgba(201,162,39,.2);border-top:3px solid #c9a227;border-top:3px solid var(--house-color,#c9a227);border-radius:3px;padding:24px 20px;transition:border-color .3s ease,box-shadow .3s ease,transform .3s ease;position:relative;overflow:hidden}.house-card:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(201,162,39,.05),transparent 60%);background:linear-gradient(180deg,var(--house-bg,rgba(201,162,39,.05)),transparent 60%);pointer-events:none}.house-card:hover{border-color:rgba(201,162,39,.5);border-color:var(--house-accent,rgba(201,162,39,.5));box-shadow:0 12px 40px rgba(0,0,0,.4),0 0 20px color-mix(in srgb,#c9a227 15%,transparent);box-shadow:0 12px 40px rgba(0,0,0,.4),0 0 20px color-mix(in srgb,var(--house-color,#c9a227) 15%,transparent);transform:translateY(-3px)}.house-card__header{display:flex;align-items:flex-start;grid-gap:14px;gap:14px;margin-bottom:16px}.house-card__meta{display:flex;flex-direction:column;grid-gap:3px;gap:3px;flex:1 1}.house-card__name{font-family:var(--font-title);font-size:.95rem;letter-spacing:.1em;color:var(--hp-gold)}.house-card__category{font-family:var(--font-sans);font-size:.72rem;color:var(--hp-cream);letter-spacing:.06em;font-weight:600}.house-card__motto{font-family:var(--font-body);font-size:.7rem;color:var(--hp-muted);font-style:italic;line-height:1.4;margin-top:3px}.house-card__divider{height:1px;background:linear-gradient(90deg,rgba(201,162,39,.4),transparent);background:linear-gradient(90deg,var(--house-color,rgba(201,162,39,.4)),transparent);margin-bottom:14px;opacity:.4}.house-card__spells{display:flex;flex-wrap:wrap;grid-gap:7px;gap:7px}.house-spell{font-family:var(--font-title);font-size:.58rem;letter-spacing:.1em;padding:4px 10px;border:1px solid color-mix(in srgb,#c9a227 40%,transparent);border:1px solid color-mix(in srgb,var(--house-color,#c9a227) 40%,transparent);color:color-mix(in srgb,#c9a227 90%,#fff);color:color-mix(in srgb,var(--house-accent,#c9a227) 90%,#fff);border-radius:2px;background:color-mix(in srgb,#c9a227 8%,transparent);background:color-mix(in srgb,var(--house-color,#c9a227) 8%,transparent);transition:all .2s ease}.house-spell:hover{background:color-mix(in srgb,#c9a227 20%,transparent);background:color-mix(in srgb,var(--house-color,#c9a227) 20%,transparent);border-color:rgba(201,162,39,.6);border-color:var(--house-accent,rgba(201,162,39,.6))}@media (max-width:960px){.frog-cards-grid{grid-template-columns:1fr 1fr}.hp-houses,.letter-cols{grid-template-columns:1fr}.letter-col-right{border-left:none;padding-left:0;border-top:1px solid rgba(139,100,20,.2);padding-top:14px;flex-direction:row;flex-wrap:wrap;grid-gap:8px 20px;gap:8px 20px}.letter-col-right__seal{display:none}}@media (max-width:640px){.frog-cards-grid{grid-template-columns:1fr}.frog-card{height:280px}.letter-inner{padding:18px 16px 20px}.letter-inner__header{grid-gap:10px;gap:10px}.hp-houses,.letter-cols{grid-template-columns:1fr}.letter-sealed{padding:18px 24px 22px}}.hp-spinner{position:relative;width:56px;height:56px;display:flex;align-items:center;justify-content:center}.hp-spinner__ring{position:absolute;inset:0;border-radius:50%;border:2px solid rgba(201,162,39,.15);border-top:2px solid var(--hp-gold,#c9a227);-webkit-animation:spinRing 1.1s linear infinite;animation:spinRing 1.1s linear infinite}.hp-spinner__star{font-size:1.2rem;color:#c9a227;color:var(--hp-gold,#c9a227);-webkit-animation:glow-pulse 2s ease-in-out infinite;animation:glow-pulse 2s ease-in-out infinite}@-webkit-keyframes spinRing{to{transform:rotate(1turn)}}@keyframes spinRing{to{transform:rotate(1turn)}}
/*# sourceMappingURL=main.26fb2039.chunk.css.map */