.App{min-height:100vh;width:100%;overflow-x:hidden}section{opacity:0;transform:translateY(30px);transition:opacity .8s ease-out,transform .8s ease-out}section.animate-in{opacity:1;transform:translateY(0)}section:first-of-type{opacity:1;transform:translateY(0)}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:#0a0a0a}::-webkit-scrollbar-thumb{background:#10b981;border-radius:5px}::-webkit-scrollbar-thumb:hover{background:#059669}*{scrollbar-width:thin;scrollbar-color:#10B981 #0a0a0a}.hero{min-height:100vh;background-color:var(--color-white);display:flex;flex-direction:column;justify-content:center;align-items:center;position:relative;padding:2rem}.hero-content{display:flex;align-items:center;justify-content:center;gap:4rem;max-width:1200px;width:100%;flex-wrap:wrap}.hero-text{flex:1;min-width:300px;text-align:left}.student-name{font-family:var(--font-body);font-size:1rem;letter-spacing:.2em;text-transform:uppercase;color:var(--color-gray);margin-bottom:2rem;font-weight:500}.book-title{font-family:var(--font-display);font-size:clamp(4rem,10vw,8rem);font-weight:900;color:var(--color-black);line-height:.9;margin-bottom:1rem;letter-spacing:-.02em}.author-name{font-family:var(--font-body);font-size:1.5rem;color:var(--color-gray);margin-bottom:3rem;font-weight:300;font-style:italic}.chapter-title{font-family:var(--font-display);font-size:2rem;color:var(--color-black);font-weight:600;border-top:2px solid var(--color-black);padding-top:1.5rem}.hero-illustration{flex:1;display:flex;justify-content:center;align-items:center;min-width:300px}.kiera-svg{width:100%;max-width:350px;height:auto;filter:drop-shadow(0 10px 30px rgba(0,0,0,.1))}.scroll-indicator{position:absolute;bottom:3rem;left:50%;transform:translate(-50%);text-align:center;color:var(--color-gray);animation:bounce 2s infinite}.scroll-arrow{font-size:2rem;margin-bottom:.5rem}.scroll-indicator p{font-size:.875rem;letter-spacing:.1em;text-transform:uppercase;font-weight:500}@keyframes bounce{0%,20%,50%,80%,to{transform:translate(-50%) translateY(0)}40%{transform:translate(-50%) translateY(-10px)}60%{transform:translate(-50%) translateY(-5px)}}@media (max-width: 768px){.hero{min-height:90vh}.hero-content{flex-direction:column;gap:2rem}.hero-text{text-align:center}.chapter-title{font-size:1.5rem}}.transformation{--progress: 0;min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;padding:4rem 2rem;overflow:hidden;--bg-color-val: calc(255 * (1 - var(--progress)));background-color:rgb(var(--bg-color-val),var(--bg-color-val),var(--bg-color-val))}.transformation-content{max-width:1200px;width:100%;display:flex;align-items:center;gap:6rem;flex-wrap:wrap;justify-content:center;position:relative;z-index:1}.svg-container{position:relative;width:256px;height:512px;flex-shrink:0;perspective:1000px;--scale: calc(.95 + var(--progress) * .05);transform:scale(var(--scale))}.svg-wrapper{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;will-change:transform,clip-path}.kiera-wrapper{z-index:2;clip-path:inset(calc(var(--progress) * 100%) 0 0 0);--rotate-y: calc((1 - var(--progress)) * 5deg);transform:perspective(1000px) rotateY(var(--rotate-y));transform-origin:center center}.emerald-wrapper{z-index:1;pointer-events:none;clip-path:inset(0 0 calc((1 - var(--progress)) * 100%) 0);--rotate-y: calc((1 - var(--progress)) * 5deg);transform:perspective(1000px) rotateY(calc(-1 * var(--rotate-y)));transform-origin:center center}.character-svg{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 20px 40px rgba(0,0,0,.15))}.emerald-wrapper .character-svg{filter:drop-shadow(0 20px 40px rgba(0,0,0,.15)) drop-shadow(0 0 30px rgba(16,185,129,.15))}.transformation-text{flex:1;min-width:300px;position:relative;min-height:200px;--threshold: max(0, sign(var(--progress) - .5));--text-color-val: calc(var(--threshold) * 255);color:rgb(var(--text-color-val),var(--text-color-val),var(--text-color-val))}.text-group{position:absolute;width:100%;will-change:transform,opacity}.transformation-text{perspective:800px}.kiera-text{--kiera-opacity: clamp(0, 1 - var(--progress) * 2, 1);--kiera-translate-y: calc(var(--progress) * 30px);--kiera-rotate-x: calc(var(--progress) * 45deg);opacity:var(--kiera-opacity);transform:translateY(var(--kiera-translate-y)) rotateX(var(--kiera-rotate-x));transform-origin:bottom center}.emerald-text{--emerald-opacity: clamp(0, (var(--progress) - .5) * 2, 1);--emerald-translate-y: calc((1 - var(--progress)) * -30px);--emerald-rotate-x: calc((1 - var(--progress)) * -45deg);opacity:var(--emerald-opacity);transform:translateY(var(--emerald-translate-y)) rotateX(var(--emerald-rotate-x));transform-origin:top center;text-shadow:0 0 25px rgba(16,185,129,.8),0 0 10px rgba(255,255,255,.3)}.transformation-title{font-family:var(--font-display);font-size:clamp(2.5rem,5vw,4rem);font-weight:700;margin-bottom:1.5rem;line-height:1.1;letter-spacing:-.02em}.transformation-description{font-family:var(--font-body);font-size:1.25rem;line-height:1.8;font-weight:300;max-width:500px}@media (max-width: 768px){.transformation-content{flex-direction:column;gap:2rem}.svg-container{width:200px;height:400px}.transformation-text{text-align:center}.transformation-description{margin:0 auto}}.chapter-navigation{min-height:100vh;background-color:var(--color-black);color:var(--color-white);padding:6rem 2rem}.chapter-navigation-content{max-width:1400px;margin:0 auto}.chapter-subtitle{text-align:center;font-size:1rem;color:#fff9;margin-top:-2rem;margin-bottom:4rem;font-weight:300}.chapters-grid{display:grid;gap:1.5rem;grid-template-columns:1fr}@media (min-width: 640px){.chapters-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 960px){.chapters-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 1280px){.chapters-grid{grid-template-columns:repeat(4,1fr)}}.chapter-card{background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:2rem;display:flex;flex-direction:column;gap:1rem;transition:all .3s ease;cursor:pointer;position:relative;overflow:hidden}.chapter-card.active{background:linear-gradient(135deg,#10b9811a,#0596690d);border-color:#10b981}.chapter-card.active:before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,#10b981,#059669)}.chapter-card.inactive{opacity:.5;cursor:not-allowed}.chapter-card.clickable{opacity:.8;cursor:pointer}.chapter-card.clickable:hover{background:#ffffff14;opacity:1;transform:translateY(-4px)}.chapter-card{text-decoration:none;color:inherit;display:flex;flex-direction:column;gap:1rem}.chapter-card.active:hover{background:linear-gradient(135deg,#10b98126,#05966914);transform:translateY(-4px);box-shadow:0 10px 30px #10b98133}.chapter-card.inactive:hover{background:#ffffff0d;opacity:.6}.chapter-number{font-family:var(--font-display);font-size:3rem;font-weight:700;line-height:1;background:linear-gradient(135deg,#10b981,#059669);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.chapter-card.inactive .chapter-number{background:#fff3;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.chapter-info{display:flex;justify-content:space-between;align-items:center;gap:1rem}.chapter-info h3{font-family:var(--font-display);font-size:1.25rem;font-weight:600;color:var(--color-white)}.chapter-status{font-size:.875rem;font-weight:500;color:#ffffff80;text-transform:uppercase;letter-spacing:.05em}.chapter-status.complete{color:#10b981}.chapter-title-text{font-family:var(--font-body);font-size:.9375rem;color:#ffffffb3;font-style:italic;margin-top:.5rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1)}@media (max-width: 768px){.chapter-navigation{padding:4rem 1.5rem}.chapters-grid{grid-template-columns:1fr}}.footer{background-color:#000;color:var(--color-white);padding:4rem 2rem 2rem;border-top:1px solid rgba(255,255,255,.1)}.footer-content{max-width:1400px;margin:0 auto}.footer-main{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:3rem;margin-bottom:3rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.1)}.footer-title{font-family:var(--font-display);font-size:1.5rem;margin-bottom:1rem;color:var(--color-white)}.footer-student{font-size:1.125rem;color:#10b981;margin-bottom:.5rem;font-weight:500}.footer-date{font-size:.9375rem;color:#ffffff80}.footer-navigation h4,.footer-about h4{font-family:var(--font-body);font-size:.875rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#fff9;margin-bottom:1.5rem}.footer-navigation nav{display:flex;flex-direction:column;gap:.75rem}.footer-navigation a{color:#ffffffb3;text-decoration:none;font-size:.9375rem;transition:all .2s ease;display:inline-block}.footer-navigation a:hover{color:#10b981;transform:translate(4px)}.footer-about p{font-size:.9375rem;line-height:1.8;color:#fff9;font-weight:300}.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.footer-copyright{font-size:.875rem;color:#fff6}.footer-buttons{display:flex;gap:1rem;flex-wrap:wrap}.back-to-home,.back-to-top{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:var(--color-white);padding:.75rem 1.5rem;border-radius:4px;font-family:var(--font-body);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .3s ease;letter-spacing:.05em;text-transform:uppercase;text-decoration:none;display:inline-block}.back-to-home:hover,.back-to-top:hover{background:#10b981;border-color:#10b981;transform:translateY(-2px)}@media (max-width: 768px){.footer{padding:3rem 1.5rem 1.5rem}.footer-main{grid-template-columns:1fr;gap:2rem}.footer-bottom{flex-direction:column;text-align:center}.footer-buttons{justify-content:center}}.content-grid-section{min-height:100vh;background-color:var(--color-black);color:var(--color-white);padding:6rem 2rem;display:flex;align-items:center;justify-content:center}.content-grid-content{max-width:1200px;width:100%}.section-title{font-family:var(--font-display);font-size:clamp(3rem,6vw,5rem);font-weight:700;margin-bottom:4rem;text-align:center;letter-spacing:-.02em}.content-grid{display:flex;flex-wrap:wrap;gap:2rem}.content-card{flex:1 1 280px;background-color:#ffffff0d;padding:2.5rem;border-radius:8px;border:1px solid rgba(255,255,255,.1);transition:all .3s ease}.content-card:hover{background-color:#ffffff14;border-color:#10b98180;transform:translateY(-6px);box-shadow:0 10px 25px #10b98133}.content-card h3{font-family:var(--font-display);font-size:1.75rem;margin-bottom:1rem;color:var(--color-white)}.content-card p{font-family:var(--font-body);font-size:1rem;line-height:1.8;color:#fffc;font-weight:300}@media (max-width: 768px){.content-grid-section{padding:4rem 1.5rem}.content-grid{grid-template-columns:1fr}}.characters-section{min-height:100vh;background-color:var(--color-black);color:var(--color-white);padding:6rem 2rem}.characters-content{max-width:1400px;margin:0 auto}.characters-subtitle{text-align:center;font-size:1.25rem;color:#fff9;margin-top:-2rem;margin-bottom:4rem;font-weight:300;letter-spacing:.1em;text-transform:uppercase}.characters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2.5rem}.character-card{background:linear-gradient(135deg,#ffffff0d,#ffffff05);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:2.5rem;transition:all .3s ease;position:relative;overflow:hidden}.character-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,#10b981,#059669);opacity:0;transition:opacity .3s ease}.character-card:hover{background:linear-gradient(135deg,#ffffff14,#ffffff0a);border-color:#10b98180;transform:translateY(-8px);box-shadow:0 15px 30px #10b98133}.character-card:hover:before{opacity:1}.character-header{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.character-header h3{font-family:var(--font-display);font-size:1.75rem;margin-bottom:.5rem;color:var(--color-white)}.character-role{font-size:1rem;color:#fff9;font-weight:300;font-style:italic}.character-analysis-details{display:flex;flex-direction:column;gap:1.5rem}.analysis-section h4{font-family:var(--font-body);font-size:.875rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#10b981;margin-bottom:.75rem}.analysis-section ul{list-style:none;padding-left:0}.analysis-section li{font-size:.95rem;line-height:1.7;color:#fffc;margin-bottom:.5rem;padding-left:1.25rem;position:relative;font-weight:300}.analysis-section li:before{content:"•";position:absolute;left:0;color:#10b981;font-weight:700}@media (max-width: 768px){.characters-section{padding:4rem 1.5rem}.characters-grid{grid-template-columns:1fr}}.quote-section{min-height:100vh;background-color:var(--color-black);color:var(--color-white);padding:6rem 2rem;display:flex;align-items:center;justify-content:center}.quote-content{max-width:900px;width:100%;position:relative}.quote-mark{font-family:var(--font-display);font-size:15rem;line-height:1;color:#ffffff0d;position:absolute;top:-4rem;left:-2rem;z-index:0;pointer-events:none}.quote-text{font-family:var(--font-display);font-size:clamp(1.75rem,4vw,2.5rem);line-height:1.6;font-weight:400;font-style:italic;margin-bottom:2rem;position:relative;z-index:1;color:var(--color-white)}.quote-attribution{display:flex;justify-content:space-between;align-items:center;margin-bottom:4rem;padding:1.5rem 0;border-top:1px solid rgba(255,255,255,.2);border-bottom:1px solid rgba(255,255,255,.2)}.quote-source{font-family:var(--font-body);font-size:.875rem;color:#10b981;letter-spacing:.1em;text-transform:uppercase;font-weight:600}.quote-speaker{font-family:var(--font-display);font-size:1.25rem;color:#fffc;font-style:italic}.quote-reflection{background:#ffffff08;padding:2.5rem;border-radius:8px;border-left:4px solid #10B981}.quote-reflection h3{font-family:var(--font-display);font-size:1.5rem;margin-bottom:1.5rem;color:var(--color-white)}.quote-reflection p{font-family:var(--font-body);font-size:1.0625rem;line-height:1.9;color:#ffffffd9;font-weight:300}@media (max-width: 768px){.quote-section{padding:4rem 1.5rem}.quote-mark{font-size:10rem;top:-3rem;left:-1rem}.quote-attribution{flex-direction:column;gap:.5rem;align-items:flex-start}.quote-reflection{padding:2rem}}.predictions-section{min-height:100vh;background-color:var(--color-black);color:var(--color-white);padding:6rem 2rem}.predictions-content{max-width:1000px;margin:0 auto}.predictions-subtitle{text-align:center;font-size:1.25rem;color:#fff9;margin-top:-2rem;margin-bottom:4rem;font-weight:300;letter-spacing:.1em;text-transform:uppercase}.predictions-list{display:flex;flex-direction:column;gap:2.5rem}.prediction-item{display:flex;gap:2rem;align-items:flex-start;padding:2rem;background:#ffffff08;border-radius:8px;border:1px solid rgba(255,255,255,.08);transition:all .3s ease;position:relative;overflow:hidden}.prediction-item:before{content:"";position:absolute;left:0;top:0;width:4px;height:100%;background:linear-gradient(180deg,#10b981,#059669);transform:scaleY(0);transform-origin:bottom;transition:transform .3s ease}.prediction-item:hover{background:#ffffff0d;border-color:#10b98180;transform:translate(8px);box-shadow:0 10px 25px #10b98133}.prediction-item:hover:before{transform:scaleY(1);transform-origin:top}.prediction-number{font-family:var(--font-display);font-size:3rem;font-weight:700;color:#10b9814d;line-height:1;flex-shrink:0;min-width:80px}.prediction-text{flex:1}.prediction-text h3{font-family:var(--font-display);font-size:1.5rem;margin-bottom:1rem;color:var(--color-white);font-weight:600}.prediction-text p{font-family:var(--font-body);font-size:1.0625rem;line-height:1.8;color:#fffc;font-weight:300}@media (max-width: 768px){.predictions-section{padding:4rem 1.5rem}.prediction-item{flex-direction:column;gap:1rem}.prediction-number{font-size:2.5rem;min-width:auto}}*{margin:0;padding:0;box-sizing:border-box}:root{--font-display: "Playfair Display", serif;--font-body: "Inter", sans-serif;--color-white: #ffffff;--color-black: #0a0a0a;--color-gray: #666666;--transition-smooth: all .6s cubic-bezier(.4, 0, .2, 1)}html{scroll-behavior:smooth}body{font-family:var(--font-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}h1,h2,h3{font-family:var(--font-display);font-weight:700}::selection{background-color:var(--color-black);color:var(--color-white)}
