@import"https://fonts.googleapis.com/css2?family=Fredoka:wght@400;500;600;700&family=Patrick+Hand&display=swap";:root{line-height:1.5;font-weight:400;color:#333;background-color:#fffdf7;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}:root{--bg-primary: #fffdf7;--bg-secondary: #f5f0e8;--card-bg: #ffffff;--border-color: #444;--border-light: #ccc;--text-primary: #2c2c2c;--text-secondary: #555;--text-muted: #888;--accent-blue: #4A90D9;--accent-blue-light: #6BB5F0;--accent-blue-dark: #2E6DB4;--accent-green: #5CB85C;--accent-orange: #F5A623;--accent-red: #E55B5B;--text-main: #2c2c2c;--accent-purple: #8B5CF6;--font-heading: "Fredoka", sans-serif;--font-body: "Patrick Hand", cursive, system-ui, sans-serif;--section-padding: 5rem 0;--container-width: 1000px;--container-padding: 1.5rem;--transition-fast: .2s ease;--transition-medium: .3s ease;--sketch-shadow: 3px 3px 0px var(--border-color);--sketch-shadow-hover: 5px 5px 0px var(--border-color);--sketch-shadow-light: 2px 2px 0px #aaa;--sketch-shadow-blue: 3px 3px 0px var(--accent-blue-dark)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);line-height:1.7;overflow-x:hidden;min-width:100%;font-size:17px;letter-spacing:.01em}#root{width:100%;min-height:100vh}a{color:var(--accent-blue);text-decoration:none;transition:color var(--transition-fast);border-bottom:2px solid var(--accent-blue);border-bottom-style:wavy}a:hover{color:var(--accent-blue-dark);border-bottom-color:var(--accent-blue-dark)}ul,ol{list-style:none}img{max-width:100%;height:auto;display:block}button{font-family:inherit;cursor:pointer;border:none;background:none}.container{max-width:var(--container-width);margin:0 auto;padding:0 var(--container-padding)}.section{padding:var(--section-padding);position:relative}.section-title{font-family:var(--font-heading);font-size:clamp(1.8rem,5vw,2.8rem);font-weight:700;text-align:center;margin-bottom:3rem;color:var(--text-primary);position:relative}.section-title:after{content:"";display:block;width:140px;height:8px;margin:.5rem auto 0;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='8'%3E%3Cpath d='M2 4 Q12 1 22 5 Q32 8 42 3 Q52 0 62 5 Q72 7 82 3 Q92 0 102 5 Q112 8 122 3 Q132 1 138 4' fill='none' stroke='%234A90D9' stroke-width='3' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat center;opacity:.85}.gradient-text{color:var(--text-primary);-webkit-text-fill-color:var(--text-primary);background:none}.sketch-card{background:var(--card-bg);border:2px solid var(--border-color);border-radius:3px;box-shadow:var(--sketch-shadow);transition:all var(--transition-medium);position:relative}.sketch-card:hover{box-shadow:var(--sketch-shadow-hover);transform:translate(-1px,-1px)}.glass-card{background:var(--card-bg);border:2px solid var(--border-color);border-radius:3px;box-shadow:var(--sketch-shadow);transition:all var(--transition-medium);position:relative;overflow:visible}.glass-card:hover{box-shadow:var(--sketch-shadow-hover);transform:translate(-1px,-1px)}.glass-card:before{display:none}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.75rem;font-family:var(--font-heading);font-size:1rem;font-weight:700;border-radius:3px;border:2px solid var(--border-color);transition:all var(--transition-medium);text-decoration:none;border-bottom:2px solid var(--border-color)}.btn-primary{background:var(--accent-blue);color:#fff;border-color:var(--accent-blue-dark);box-shadow:3px 3px 0 var(--accent-blue-dark)}.btn-primary:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--accent-blue-dark);color:#fff;background:var(--accent-blue-light);border-bottom:2px solid var(--accent-blue-dark)}.btn-secondary{background:var(--card-bg);color:var(--accent-blue);border-color:var(--accent-blue);box-shadow:var(--sketch-shadow-light)}.btn-secondary:hover{background:var(--bg-secondary);transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--accent-blue-dark);color:var(--accent-blue-dark);border-bottom:2px solid var(--accent-blue)}.scroll-progress{position:fixed;top:0;left:0;height:4px;background:var(--accent-blue);z-index:1001;transition:width .05s linear;pointer-events:none}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:.75rem 0;background:var(--bg-primary)!important;border-bottom:2px solid var(--border-color)}.nav-container{max-width:var(--container-width);margin:0 auto;padding:0 var(--container-padding);display:flex;align-items:center;justify-content:space-between}.nav-logo{font-family:var(--font-heading);font-size:1.75rem;font-weight:700;color:var(--accent-blue);border-bottom:none;-webkit-text-fill-color:var(--accent-blue);background:none}.nav-logo:hover{color:var(--accent-blue-dark)}.nav-links{display:flex;gap:2rem}.nav-links a{font-size:1rem;font-weight:700;color:var(--text-secondary);position:relative;border-bottom:none}.nav-links a:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:0;border-bottom:none;background:none;transition:width var(--transition-medium)}.nav-links a:hover{color:var(--text-primary)}.nav-links a:hover:after{width:100%;height:4px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='4'%3E%3Cpath d='M0 2 Q5 0 10 2 Q15 4 20 2 Q25 0 30 2 Q35 4 40 2 Q45 0 50 2 Q55 4 60 2 Q65 0 70 2 Q75 4 80 2 Q85 0 90 2 Q95 4 100 2' fill='none' stroke='%234A90D9' stroke-width='2'/%3E%3C/svg%3E") repeat-x}.nav-toggle{display:none;flex-direction:column;gap:5px;padding:.5rem}.nav-toggle span{width:24px;height:2px;background:var(--text-primary);border-radius:0}.hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden;padding-top:80px;background:var(--bg-primary)}.hero-bg{display:none}.hero-container{display:flex;align-items:center;justify-content:center;gap:4rem;max-width:var(--container-width);width:100%;margin:0 auto;padding:0 var(--container-padding);z-index:1}.hero-content{text-align:left;z-index:1;flex:1;max-width:550px}.hero-image-wrapper{position:relative;flex-shrink:0;isolation:isolate}.hero-image-glow{position:absolute;inset:-8px;border:3px solid var(--border-color);border-radius:50%;background:var(--bg-primary);filter:none;opacity:1;animation:none;box-shadow:4px 4px 0 var(--border-color);z-index:0}.hero-image{width:280px;height:280px;object-fit:cover;object-position:center top;border-radius:50%;border:3px solid var(--border-color);background:var(--card-bg);position:relative;z-index:1}.stick-figure{position:absolute;top:50%;left:50%;width:80px;height:90px;margin-top:-90px;margin-left:-40px;z-index:-1;pointer-events:none;opacity:1;transform-origin:bottom center;transform:rotate(45deg) translateY(-60px);transition:all .5s cubic-bezier(.34,1.56,.64,1);color:var(--border-color)}.hero-image-wrapper:hover .stick-figure{opacity:1;transform:rotate(45deg) translateY(-135px)}.waving-arm-left,.waving-arm-right{transform-origin:40px 55px}.hero-image-wrapper:hover .waving-arm-left{animation:wave-left 2.5s ease-in-out infinite;animation-delay:.1s}.hero-image-wrapper:hover .waving-arm-right{animation:wave-right 2.5s ease-in-out infinite;animation-delay:.1s}@keyframes wave-right{0%{transform:rotate(0)}8%{transform:rotate(-20deg)}16%{transform:rotate(12deg)}24%{transform:rotate(-14deg)}32%{transform:rotate(6deg)}40%{transform:rotate(-8deg)}48%{transform:rotate(0)}to{transform:rotate(0)}}@keyframes wave-left{0%{transform:rotate(0)}8%{transform:rotate(20deg)}16%{transform:rotate(-12deg)}24%{transform:rotate(14deg)}32%{transform:rotate(-6deg)}40%{transform:rotate(8deg)}48%{transform:rotate(0)}to{transform:rotate(0)}}.hero-greeting{font-size:1.15rem;color:var(--text-secondary);margin-bottom:.25rem}.hero-name{font-family:var(--font-heading);font-size:clamp(2.5rem,8vw,4.5rem);font-weight:700;line-height:1.1;margin-bottom:.75rem;color:var(--text-primary)}.hero-name .gradient-text{color:var(--text-primary);-webkit-text-fill-color:var(--text-primary);background:none;position:relative}.hero-name .gradient-text:after{content:"";display:block;width:100%;height:10px;margin-top:4px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='10'%3E%3Cpath d='M2 5 Q15 1 30 6 Q45 9 60 4 Q75 1 90 6 Q105 9 120 4 Q135 1 150 6 Q165 9 180 4 Q195 1 210 6 Q225 9 240 4 Q255 1 270 6 Q285 9 298 5' fill='none' stroke='%234A90D9' stroke-width='3.5' stroke-linecap='round'/%3E%3C/svg%3E") repeat-x;opacity:.8}.hero-tagline{font-size:clamp(1rem,2.5vw,1.15rem);color:var(--text-secondary);max-width:500px;margin:0 0 2rem}.hero-cta{display:flex;gap:1rem;justify-content:flex-start;flex-wrap:wrap}.scroll-indicator{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--text-muted);font-size:.9rem}.mouse{width:24px;height:40px;border:2px solid var(--text-muted);border-radius:0;position:relative;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='40' viewBox='0 0 24 40'%3E%3Cpath d='M12 5 L12 30 M6 24 L12 30 L18 24' fill='none' stroke='%23888' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat center;border:none;animation:scroll-bob 2s ease-in-out infinite}@keyframes scroll-bob{0%,to{transform:translateY(0)}50%{transform:translateY(8px)}}.wheel{display:none}.about{background:var(--bg-secondary);border-top:2px dashed var(--border-light);border-bottom:2px dashed var(--border-light)}.about-content{display:grid;grid-template-columns:1.5fr 1fr;gap:2rem}.about-text{padding:2rem}.about-intro{font-size:1.15rem;margin-bottom:1.25rem;color:var(--text-primary)}.about-text p{color:var(--text-secondary);margin-bottom:1rem}.about-text strong{color:var(--text-primary)}.about-stats{display:flex;gap:2rem;margin-top:2rem;padding-top:2rem;border-top:2px dashed var(--border-light)}.stat{text-align:center}.stat-number{display:block;font-family:var(--font-heading);font-size:2rem;font-weight:700;color:var(--accent-blue)}.stat-label{font-size:.85rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.tech-stack{padding:1.5rem}.tech-stack h3{font-family:var(--font-heading);font-size:1.25rem;margin-bottom:1.25rem;color:var(--text-primary)}.tech-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.tech-item{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;border:1.5px solid var(--border-light);border-radius:3px;transition:all var(--transition-fast);background:var(--bg-primary)}.tech-item:hover{border-color:var(--border-color);transform:rotate(-1deg);box-shadow:2px 2px 0 var(--border-color)}.tech-item img{width:24px;height:24px}.tech-item span{font-size:.9rem;color:var(--text-secondary);font-weight:700}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.project-card{padding:1.75rem;display:flex;flex-direction:column;transform:rotate(0);transition:all var(--transition-medium)}.project-card:nth-child(2n){transform:rotate(.5deg)}.project-card:nth-child(odd){transform:rotate(-.3deg)}.project-card:hover{transform:rotate(0) translate(-2px,-2px)!important;box-shadow:5px 5px 0 var(--border-color)}.project-card.featured{background:var(--card-bg);border-color:var(--border-color);border-width:2.5px}.project-card.featured:hover{border-color:var(--accent-blue)}.project-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.project-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border:2px solid var(--border-color);border-radius:3px;color:var(--text-primary);background:var(--bg-secondary)}.project-links{display:flex;gap:.75rem}.project-links a{color:var(--text-muted);border-bottom:none;transition:color var(--transition-fast)}.project-links a:hover{color:var(--accent-blue);border-bottom:none}.project-title{font-family:var(--font-heading);font-size:1.3rem;font-weight:700;margin-bottom:.5rem}.project-description{color:var(--text-secondary);font-size:.95rem;margin-bottom:1rem;flex-grow:1}.project-features{margin-bottom:1rem;padding-left:1rem}.project-features li{color:var(--text-secondary);font-size:.85rem;margin-bottom:.4rem;position:relative}.project-features li:before{content:"→";position:absolute;left:-1rem;color:var(--accent-blue)}.project-tech{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:auto}.tech-tag{padding:.25rem .6rem;background:var(--bg-secondary);border:1.5px solid var(--border-color);border-radius:3px;font-size:.8rem;font-weight:700;color:var(--text-primary)}.private-badge{display:flex;align-items:center;gap:.35rem;padding:.25rem .6rem;background:var(--bg-secondary);border:1.5px solid var(--border-light);border-radius:3px;font-size:.75rem;color:var(--text-muted);font-weight:700}.github-section{margin-top:4rem;padding-top:4rem;border-top:2px dashed var(--border-light)}.github-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.github-repo{padding:1.5rem}.github-repo h4{font-family:var(--font-heading);font-size:1.1rem;margin-bottom:.5rem;color:var(--text-primary)}.github-repo p{font-size:.9rem;color:var(--text-muted);margin-bottom:1rem;min-height:2.5em}.repo-meta{display:flex;gap:1rem;font-size:.85rem;color:var(--text-muted)}.repo-meta span{display:flex;align-items:center;gap:.35rem}.repo-lang{width:12px;height:12px;border-radius:50%;display:inline-block}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-light);border-top-color:var(--text-primary);border-radius:50%;animation:spin 1s linear infinite;margin:2rem auto}@keyframes spin{to{transform:rotate(360deg)}}.experience{background:var(--bg-secondary);border-top:2px dashed var(--border-light);border-bottom:2px dashed var(--border-light)}.timeline{display:flex;flex-direction:column;gap:1.5rem;max-width:750px;margin:0 auto;position:relative}.timeline:before{content:"";position:absolute;left:-24px;top:0;bottom:0;width:6px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='6' height='200'%3E%3Cpath d='M3 0 Q1 10 3 20 Q5 30 3 40 Q1 50 3 60 Q5 70 3 80 Q1 90 3 100 Q5 110 3 120 Q1 130 3 140 Q5 150 3 160 Q1 170 3 180 Q5 190 3 200' fill='none' stroke='%23ccc' stroke-width='2'/%3E%3C/svg%3E") repeat-y}.timeline-item{padding:1.75rem;position:relative}.timeline-item:before{content:"●";position:absolute;left:-30px;top:1.75rem;font-size:16px;color:var(--accent-blue);line-height:1}.timeline-date{font-size:.85rem;color:var(--accent-blue);font-weight:700;margin-bottom:.5rem}.timeline-title{font-family:var(--font-heading);font-size:1.3rem;font-weight:700;margin-bottom:.25rem}.timeline-company{color:var(--text-secondary);margin-bottom:1rem}.timeline-details{padding-left:1.25rem}.timeline-details li{color:var(--text-secondary);font-size:.95rem;margin-bottom:.5rem;position:relative}.timeline-details li:before{content:"•";position:absolute;left:-1rem;color:var(--accent-blue)}.contact{text-align:center}.contact-intro{font-size:1.1rem;color:var(--text-secondary);max-width:500px;margin:0 auto 3rem}.contact-wrapper{display:grid;grid-template-columns:1.5fr 1fr;gap:2rem;max-width:900px;margin:0 auto;text-align:left}.contact-form{padding:2rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-size:.9rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.form-group input,.form-group textarea{width:100%;padding:.75rem 1rem;font-family:var(--font-heading);font-size:1rem;color:var(--text-primary);background:var(--bg-primary);border:2px solid var(--border-color);border-radius:3px;transition:all var(--transition-fast)}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent-blue);box-shadow:3px 3px 0 var(--accent-blue)}.form-group textarea{resize:vertical;min-height:120px}.form-submit{width:100%}.form-submit:disabled{opacity:.6;cursor:not-allowed}.form-success{margin-top:1rem;padding:.75rem;background:#e8f8e8;border:2px solid var(--accent-green);border-radius:3px;color:var(--accent-green);font-size:.9rem;font-weight:700;text-align:center}.form-error{margin-top:1rem;padding:.75rem;background:#fde8e8;border:2px solid var(--accent-red);border-radius:3px;color:var(--accent-red);font-size:.9rem;font-weight:700;text-align:center}.content-header-title{font-size:3.5rem;margin-bottom:1rem;text-align:center}.content-header-subtitle{font-size:1.1rem;color:var(--text-muted);max-width:600px;margin:0 auto 2rem;text-align:center;line-height:1.6}.social-links{display:flex;flex-direction:column;gap:1rem}.social-label{font-size:.9rem;color:var(--text-muted);text-align:center;font-weight:700}.social-cards{display:flex;flex-direction:column;gap:1rem}.contact-card{padding:1.5rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;text-align:center;border-bottom:none}.contact-card:hover{transform:translate(-2px,-2px);border-color:var(--accent-blue);box-shadow:var(--sketch-shadow-hover);border-bottom:none}.contact-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border:2px solid var(--border-color);border-radius:50%;color:var(--text-primary);background:var(--bg-secondary)}.contact-label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:700}.contact-value{font-family:var(--font-heading);font-weight:700;font-size:.95rem;color:var(--text-primary)}.footer{padding:2rem 0;text-align:center;border-top:2px solid var(--border-color);color:var(--text-muted);font-size:.9rem;background:var(--bg-primary)}@media(max-width:968px){.about-content,.projects-grid{grid-template-columns:1fr}.project-card:nth-child(2n),.project-card:nth-child(odd){transform:none}.contact-wrapper{grid-template-columns:1fr}.social-cards{flex-direction:row;justify-content:center}.contact-card{flex:1}}@media(max-width:768px){:root{--section-padding: 3.5rem 0}.scroll-indicator{display:none}.nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:var(--bg-primary);flex-direction:column;padding:1.5rem;gap:1rem;border-bottom:2px solid var(--border-color)}.nav-links.active,.nav-toggle{display:flex}.hero-container{flex-direction:column-reverse;gap:1rem;text-align:center;padding-top:2rem}.hero-content{text-align:center;max-width:100%;display:flex;flex-direction:column;align-items:center}.hero-image{width:180px;height:180px}.hero-image-glow{inset:-6px}.stick-figure{display:none}.hero-name{margin-bottom:.5rem}.hero-tagline{margin-bottom:1.5rem;width:100%}.typewriter{min-width:unset;width:100%;display:inline;white-space:normal;word-break:break-word}.hero-cta{flex-direction:column;align-items:center;gap:.75rem}.btn{width:100%;max-width:280px}.about-stats{justify-content:center}.timeline:before{display:none}.timeline-item:before{display:none}.contact-links{grid-template-columns:1fr 1fr}}@media(max-width:480px){.tech-grid,.contact-links,.github-grid{grid-template-columns:1fr}}.animate-fade-up{opacity:0;transform:translateY(20px);animation:fadeUp .6s ease forwards}.delay-1{animation-delay:.1s}.delay-2{animation-delay:.2s}.delay-3{animation-delay:.3s}.delay-4{animation-delay:.4s}@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}.reveal{opacity:0;transform:translateY(30px);transition:all .6s cubic-bezier(.4,0,.2,1)}.reveal.active{opacity:1;transform:translateY(0)}@keyframes wobble{0%,to{transform:rotate(0)}25%{transform:rotate(-1deg)}75%{transform:rotate(1deg)}}.tech-item img{transition:transform .3s ease}.tech-item:hover img{transform:scale(1.1) rotate(-5deg)}.typewriter{display:inline-block;min-width:23ch}.typewriter-cursor{display:inline-block;animation:blink 1s step-end infinite;color:var(--accent-blue);font-weight:300;margin-left:2px}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.project-view-hint{margin-top:1rem;padding-top:1rem;border-top:1.5px dashed var(--border-light);text-align:center;opacity:0;transform:translateY(8px);transition:all var(--transition-medium)}.project-view-hint span{font-size:.85rem;color:var(--accent-blue);font-weight:700}.project-card:hover .project-view-hint{opacity:1;transform:translateY(0)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;padding:2rem;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{max-width:700px;width:100%;max-height:90vh;overflow-y:auto;position:relative;animation:slideUp .3s ease;background:var(--card-bg)}.modal-content.glass-card:before{display:none}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-close{position:absolute;top:1rem;right:1rem;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);border:2px solid var(--border-color);border-radius:3px;color:var(--text-primary);font-size:1.5rem;cursor:pointer;transition:all var(--transition-fast);z-index:10}.modal-close:hover{background:var(--accent-blue);color:#fff;transform:rotate(90deg)}.modal-demo{width:100%;border-radius:0;overflow:hidden;background:var(--bg-secondary);border-bottom:2px solid var(--border-color)}.modal-demo img,.modal-demo video{width:100%;height:auto;display:block}.modal-body{padding:2rem}.modal-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.modal-icon{width:52px;height:52px;display:flex;align-items:center;justify-content:center;border:2px solid var(--border-color);border-radius:3px;color:var(--text-primary);background:var(--bg-secondary)}.modal-title{font-family:var(--font-heading);font-size:1.65rem;font-weight:700;color:var(--text-primary);-webkit-text-fill-color:var(--text-primary);background:none}.modal-description{color:var(--text-secondary);font-size:1rem;line-height:1.7;margin-bottom:1.5rem}.modal-features{margin-bottom:1.5rem}.modal-features h3{font-family:var(--font-heading);font-size:1rem;font-weight:700;color:var(--text-primary);margin-bottom:.75rem}.modal-features ul{padding-left:1.25rem}.modal-features li{color:var(--text-secondary);font-size:.95rem;margin-bottom:.5rem;position:relative}.modal-features li:before{content:"→";position:absolute;left:-1.25rem;color:var(--accent-blue)}.modal-tech{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.modal-actions{display:flex;gap:1rem;flex-wrap:wrap}.modal-actions .btn{display:inline-flex;align-items:center;gap:.5rem}@media(max-width:768px){.modal-overlay{padding:1rem}.modal-content{max-height:95vh}.modal-body{padding:1.5rem}.modal-title{font-size:1.4rem}}body:before{content:"";position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100' height='100' filter='url(%23n)' opacity='0.015'/%3E%3C/svg%3E");pointer-events:none;z-index:-1}.subsection-title{font-family:var(--font-heading);font-size:1.4rem;font-weight:700;display:flex;align-items:center;gap:.75rem;margin-bottom:2rem;color:var(--text-secondary)}.nav-active{color:var(--text-primary)!important}.nav-active:after{width:100%!important}.content-page{min-height:100vh}.content-header{padding:7rem 0 2rem;text-align:center}.content-header-title{font-family:var(--font-heading);font-size:clamp(2rem,5vw,3rem);font-weight:700}.content-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;max-width:var(--container-width);margin:0 auto;padding:0 var(--container-padding);padding-bottom:6rem}.hub-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-bottom:4rem}.hub-card-wrapper{display:block;text-decoration:none;border-bottom:none;color:inherit}.hub-card-wrapper:hover{color:inherit;border-bottom:none}.hub-card{display:flex;flex-direction:column;padding:2.5rem;height:100%;transition:all var(--transition-medium)}.hub-card-disabled{opacity:.8;cursor:default;background:#ffffff80;border-style:dashed}.hub-card-disabled:hover{transform:none;box-shadow:var(--sketch-shadow)}.hub-card-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.hub-card-icon{font-size:2rem}.hub-card-title{font-family:var(--font-heading);font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.hub-card-description{color:var(--text-secondary);font-size:1.05rem;margin-bottom:1.5rem;line-height:1.6}.hub-card-preview{background:var(--bg-secondary);padding:1.25rem;border-radius:4px;border:1.5px dashed var(--border-light);margin-bottom:1.5rem;flex-grow:1}.hub-preview-text{font-size:.95rem;color:var(--text-secondary);margin-bottom:.5rem}.hub-preview-text:last-child{margin-bottom:0}.hub-preview-covers{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;margin-top:.5rem}.hub-mini-cover{width:45px;height:65px;object-fit:cover;border:1.5px solid var(--border-color);border-radius:2px;box-shadow:2px 2px 0 var(--border-color);transition:transform var(--transition-fast)}.hub-mini-cover:hover{transform:translateY(-2px) rotate(2deg)}.hub-mini-cover-more{width:45px;height:65px;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);border:1.5px dashed var(--border-color);border-radius:2px;color:var(--text-secondary);font-size:.85rem;font-weight:700}.hub-card-link{font-family:var(--font-heading);font-weight:700;color:var(--accent-blue);display:inline-flex;align-items:center;gap:.5rem;margin-top:auto}.hub-card-disabled .hub-card-link{color:var(--text-muted)}.back-link{display:inline-block;font-family:var(--font-heading);font-weight:600;color:var(--text-muted);margin-bottom:1.5rem;border-bottom:2px solid transparent}.back-link:hover{color:var(--accent-blue);border-bottom:2px solid var(--accent-blue);border-bottom-style:wavy}.stub-container{display:flex;justify-content:center;padding:4rem 0}.stub-card{text-align:center;padding:3rem 2rem;max-width:500px;width:100%}.stub-icon{font-size:3rem;display:block;margin-bottom:1rem}.stub-title{font-family:var(--font-heading);font-size:1.8rem;font-weight:700;margin-bottom:1rem;color:var(--text-primary)}.stub-text{color:var(--text-secondary);font-size:1.1rem}.bookshelf-group{margin-bottom:4rem}.bookshelf-group-title{font-family:var(--font-heading);font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:2px dashed var(--border-light)}.book-thoughts{margin-top:1rem;padding-top:1rem;border-top:1px dashed var(--border-light);font-size:.95rem;color:var(--text-secondary);line-height:1.6}.bookshelf-section{padding:0}.section-title{display:flex;flex-direction:column;gap:.25rem;margin-bottom:2rem}.section-subtitle{font-size:.9rem;color:var(--text-muted);font-weight:500;font-family:var(--font-body)}.sketchy-shelf-container{position:relative;padding-bottom:2rem}.bookshelf{display:grid;grid-template-columns:repeat(2,1fr);gap:2.5rem;position:relative;z-index:1}.shelf-line{position:absolute;bottom:-.5rem;left:-2%;width:104%;height:8px;background:var(--text-main);border-radius:20% 80% 30% 70%/50%;opacity:.8;transform:rotate(-.25deg);box-shadow:2px 3px #0003}.shelf-line:after{content:"";position:absolute;top:4px;left:2%;width:96%;height:2px;background:#ffffff1a;border-radius:50%}.book-card{height:100%;padding:1.25rem;display:flex;flex-direction:row;align-items:flex-end;gap:1.5rem;background:#ffffff08;border:3px solid var(--text-main);border-radius:4px 12px 6px 15px/12px 4px 15px 6px;box-shadow:6px 6px 0 var(--text-main);transition:transform .2s ease,box-shadow .2s ease}.book-card:hover{transform:translate(-3px,-3px) rotate(.5deg);box-shadow:10px 10px 0 var(--accent-blue)}.book-cover-wrapper{position:relative;width:100px;flex-shrink:0;transform:rotate(-2deg);transition:transform .3s ease}.book-card:hover .book-cover-wrapper{transform:rotate(0) scale(1.05)}.book-cover{width:100px;height:145px;object-fit:cover;border:2px solid var(--text-main);border-radius:2px;box-shadow:4px 4px #0000004d}.book-info{flex:1;display:flex;flex-direction:column;gap:.5rem}.book-status-badge{align-self:flex-start;padding:.2rem .6rem;border-radius:4px 8px 3px 6px/6px 3px 8px 4px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border:2px solid currentColor;margin-bottom:.25rem}.status-reading{background:#a855f726;color:var(--accent-purple)}.status-finished{background:#22c55e1a;color:#22c55e}.status-next{background:#06b6d41a;color:var(--accent-cyan)}.book-title{font-family:var(--font-heading);font-size:1.15rem;font-weight:700;margin:0;line-height:1.2;color:var(--text-main)}.book-author{font-size:.9rem;color:var(--text-muted);font-weight:500}@media(max-width:768px){.content-header{padding:6rem 0 1.5rem}.bookshelf{grid-template-columns:1fr}}.newsletter-embed-container{margin-top:1rem}.beehiiv-embed{width:100%!important}.newsletter-archive-link{margin-top:1.5rem;text-align:center}.newsletter-archive-link .btn{width:100%}.hub-card-double{grid-column:span 2}@media(max-width:768px){.hub-card-double{grid-column:span 1}}
