@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:Inter,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);overflow-x:hidden;transition:background-color .3s ease,color .3s ease}:root{--graphite: #302E2F;--stone-gray: #DAD5CF;--bg-primary: #FFFFFF;--bg-secondary: #F5F5F5;--bg-navbar: #F5F5F5;--text-primary: #302E2F;--text-secondary: #666666;--text-muted: #999999;--border-color: #E0E0E0;--hover-bg: #302E2F;--hover-text: #FFFFFF;--card-bg: #F5F5F5;--badge-bg: #F0F0F0;--project-card-bg: #F5F5F5}[data-theme=dark]{--bg-primary: #302E2F;--bg-secondary: #2A2829;--bg-navbar: #2A2829;--text-primary: #DAD5CF;--text-secondary: #B8B3AC;--text-muted: #8A8580;--border-color: #4A4849;--hover-bg: #DAD5CF;--hover-text: #302E2F;--card-bg: #2A2829;--badge-bg: #3A3839;--project-card-bg: #3A3839}.navbar{position:fixed;top:2rem;left:50%;transform:translate(-50%);background:var(--bg-navbar);padding:.75rem 2rem;border-radius:50px;display:flex;gap:2rem;align-items:center;z-index:100;box-shadow:0 2px 10px #0000000d;transition:transform .3s ease,opacity .3s ease}.navbar.hidden{transform:translate(-50%) translateY(-150%);opacity:0}.navbar.visible{transform:translate(-50%) translateY(0);opacity:1}.navbar a{text-decoration:none;color:var(--text-secondary);font-size:.9rem;font-weight:500;display:flex;align-items:center;gap:.5rem;transition:all .3s ease}.navbar a:hover,.navbar a.active{color:var(--hover-text);background:var(--hover-bg);padding:.5rem 1rem;border-radius:25px}.theme-toggle{background:none;border:none;color:var(--text-secondary);font-size:1.2rem;cursor:pointer;padding:.5rem;border-radius:50%;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.theme-toggle:hover{background:var(--hover-bg);color:var(--hover-text)}.hero-section{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:8rem 2rem 4rem}.hero-content{display:flex;align-items:center;gap:4rem;max-width:1200px;width:100%}.hero-text{flex:1}.hero-image{flex:1;display:flex;justify-content:center}.hero-image img{max-width:400px;width:100%;border-radius:20px}.badge{display:inline-block;background:var(--badge-bg);padding:.5rem 1rem;border-radius:20px;font-size:.85rem;color:var(--text-secondary);margin-bottom:1.5rem}.hero-text h1{font-size:3.5rem;font-weight:700;line-height:1.2;margin-bottom:.5rem;color:var(--text-primary)}.hero-text h2{font-size:1.5rem;font-weight:500;color:var(--text-primary);margin-bottom:1rem}.typing-cursor{display:inline-block;width:2px;height:1.5rem;background:var(--text-primary);margin-left:4px;animation:blink 1s infinite}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.hero-text p{color:var(--text-secondary);line-height:1.8;margin-bottom:1.5rem}.tags{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.tag{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-secondary)}.tag i{font-size:1rem}.hero-social-buttons{display:flex;gap:.75rem;margin-top:1.5rem;flex-wrap:wrap}.hero-social-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:25px;background:var(--badge-bg);color:var(--text-primary);text-decoration:none;font-size:.85rem;font-weight:500;transition:all .3s ease;cursor:pointer;border:1px solid var(--border-color)}.hero-social-btn:hover{background:var(--hover-bg);color:var(--hover-text);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.hero-social-btn i{font-size:1rem}.hero-buttons{display:flex;gap:1rem;margin-bottom:2rem}.btn{padding:.75rem 1.5rem;border-radius:8px;text-decoration:none;font-weight:600;font-size:.9rem;transition:all .3s ease;border:none;cursor:pointer;display:inline-flex;align-items:center;gap:.5rem}.btn-primary{background:var(--text-primary);color:var(--bg-primary)}.btn-primary:hover{opacity:.8;transform:translateY(-2px)}.btn-secondary{background:transparent;color:var(--text-primary);border:2px solid var(--border-color)}.btn-secondary:hover{border-color:var(--text-primary)}.social-links{display:flex;gap:1.5rem;align-items:center}.social-links span{font-size:.9rem;color:var(--text-secondary)}.social-links a{color:var(--text-primary);font-size:1.2rem;transition:all .3s ease}.social-links a:hover{color:var(--text-secondary);transform:scale(1.1)}.projects-section{padding:6rem 2rem;max-width:1200px;margin:0 auto}.section-title{font-size:2rem;font-weight:700;margin-bottom:3rem;color:var(--text-primary)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.project-card{background:var(--project-card-bg);border-radius:16px;padding:2rem;transition:all .3s ease}.project-icon{font-size:2.5rem;margin-bottom:1.5rem;color:var(--text-primary)}.project-info h3{font-size:1.25rem;margin-bottom:.75rem;font-weight:600;color:var(--text-primary)}.project-info p{color:var(--text-secondary);margin-bottom:1.5rem;line-height:1.6}.project-link{color:var(--text-primary);text-decoration:none;font-weight:600;display:flex;align-items:center;gap:.5rem}.project-link:hover i{transform:translate(5px)}.project-link i{transition:transform .3s ease}.coming-soon{opacity:.7}.status-badge{background:var(--border-color);padding:.4rem .8rem;border-radius:20px;font-size:.8rem;color:var(--text-secondary)}.contact-section{padding:6rem 2rem;max-width:800px;margin:0 auto;text-align:center}.contact-card{background:var(--card-bg);padding:4rem;border-radius:20px}.contact-card h2{font-size:2rem;margin-bottom:2rem;color:var(--text-primary)}.contact-links{display:flex;justify-content:center;gap:3rem;flex-wrap:wrap}.contact-item{color:var(--text-primary);text-decoration:none;display:flex;flex-direction:column;align-items:center;gap:.75rem;transition:all .3s ease}.contact-item i{font-size:2rem}.contact-item:hover{transform:scale(1.1)}.page-section{min-height:100vh;padding:8rem 2rem 4rem;display:flex;justify-content:center}.page-content{max-width:1000px;width:100%}.page-title{font-size:3rem;font-weight:700;margin-bottom:1rem;color:var(--text-primary);text-align:center}.page-subtitle{color:var(--text-secondary);text-align:center;margin-bottom:3rem}.about-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem}.about-card{background:var(--project-card-bg);padding:2rem;border-radius:16px;text-align:center;transition:all .3s ease}.about-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #0000001a}.about-card i{font-size:3rem;color:var(--text-primary);margin-bottom:1rem}.about-card h3{font-size:1.25rem;margin-bottom:.75rem;color:var(--text-primary)}.about-card p{color:var(--text-secondary)}.bio-letter{background:var(--project-card-bg);border-radius:20px;padding:3rem;text-align:center}.bio-letter-header{margin-bottom:2rem}.bio-letter-header img{width:140px;height:140px;border-radius:50%;object-fit:cover}.bio-letter-body p{color:var(--text-secondary);font-size:1.05rem;line-height:1.8;margin-bottom:1.2rem}.bio-letter-body p:last-child{margin-bottom:0}.bio-content{max-width:800px;margin:0 auto}.bio-header{display:flex;align-items:center;gap:2rem;margin-bottom:3rem;padding-bottom:2rem;border-bottom:2px solid var(--border-color)}.bio-avatar{width:100px;height:100px;border-radius:50%;overflow:hidden;border:3px solid var(--text-primary);flex-shrink:0}.bio-avatar img{width:100%;height:100%;object-fit:cover}.bio-intro h1{font-size:3rem;font-weight:700;color:var(--text-primary)}.bio-aka{color:var(--text-muted);font-size:1.1rem;font-style:italic}.bio-text{display:flex;flex-direction:column;gap:2rem}.bio-paragraph{font-size:1.1rem;line-height:1.8;color:var(--text-secondary)}.bio-paragraph strong{color:var(--text-primary)}.bio-section{padding:1.5rem;background:var(--project-card-bg);border-radius:16px;transition:all .3s ease}.bio-section:hover{transform:translate(5px)}.bio-section h2{font-size:1.25rem;color:var(--text-primary);margin-bottom:1rem;display:flex;align-items:center;gap:.75rem}.bio-section h2 i{color:var(--text-secondary)}.bio-section p{color:var(--text-secondary);line-height:1.6}.bio-section p strong{color:var(--text-primary)}.bio-tags{display:flex;flex-wrap:wrap;gap:.75rem}.bio-tag{background:var(--border-color);padding:.5rem 1rem;border-radius:20px;font-size:.9rem;color:var(--text-primary);transition:all .3s ease}.bio-tag:hover{background:var(--text-primary);color:var(--bg-primary);transform:scale(1.05)}.resume-page{max-width:900px;margin:0 auto}.resume-header{display:flex;gap:3rem;margin-bottom:3rem;padding-bottom:3rem;border-bottom:2px solid var(--border-color)}.resume-header-left{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.resume-photo{width:120px;height:120px;border-radius:50%;overflow:hidden;border:3px solid var(--text-primary)}.resume-photo img{width:100%;height:100%;object-fit:cover}.resume-contact{display:flex;flex-direction:column;gap:.75rem;font-size:.9rem}.resume-contact p{display:flex;align-items:center;gap:.75rem;color:var(--text-secondary)}.resume-contact i{color:var(--text-primary);width:20px;text-align:center}.resume-header-right{flex:1}.resume-name{font-size:3rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.resume-title{font-size:1.25rem;color:var(--text-secondary);margin-bottom:1rem}.resume-desc{color:var(--text-secondary);line-height:1.6}.resume-body{display:grid;grid-template-columns:1.2fr 1fr;gap:3rem}.resume-section{margin-bottom:2.5rem}.resume-section-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:3px solid var(--text-primary)}.resume-timeline{position:relative;padding-left:1.5rem}.timeline-item{position:relative;padding-bottom:1.5rem;padding-left:1.5rem;border-left:2px solid var(--border-color)}.timeline-item:last-child{border-left-color:transparent}.timeline-dot{position:absolute;left:-2.35rem;top:.25rem;width:12px;height:12px;border-radius:50%;background:var(--text-primary)}.timeline-period{display:block;font-size:.85rem;color:var(--text-muted);margin-bottom:.25rem}.timeline-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.timeline-company{color:var(--text-secondary);font-size:.9rem}.timeline-degree{color:var(--text-secondary);font-size:.9rem;margin-bottom:.25rem}.timeline-detail{color:var(--text-muted);font-size:.85rem}.expertise-cloud{display:flex;flex-wrap:wrap;gap:.75rem}.expertise-tag{background:var(--project-card-bg);padding:.75rem 1.25rem;border-radius:12px;font-weight:500;color:var(--text-primary);transition:all .3s ease}.expertise-tag:hover{transform:scale(1.05);box-shadow:0 5px 15px #0000001a}.software-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.software-item{display:flex;flex-direction:column;gap:.5rem}.software-icon{font-size:1.5rem;color:var(--text-primary)}.software-name{font-size:.85rem;font-weight:500;color:var(--text-secondary)}.software-bar{width:100%;height:6px;background:var(--border-color);border-radius:10px;overflow:hidden}.software-progress{height:100%;background:var(--text-primary);border-radius:10px}@media (max-width: 768px){.resume-header{flex-direction:column;text-align:center}.resume-body{grid-template-columns:1fr}.resume-name{font-size:2rem}.page-section{padding:5rem 1rem 3rem}.resume-section{padding:1rem 0}}.bio-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.bio-info-card,.bio-skills-card,.bio-hobbies-card,.bio-3ds-card{background:var(--project-card-bg);border-radius:20px;padding:2rem;transition:all .3s ease}.bio-info-card:hover,.bio-skills-card:hover,.bio-hobbies-card:hover,.bio-3ds-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #0000001a}.bio-info-card h2,.bio-skills-card h2,.bio-hobbies-card h2,.bio-3ds-card h2{font-size:1.5rem;margin-bottom:1.5rem;color:var(--text-primary)}.bio-info-list{display:flex;flex-direction:column;gap:1rem}.bio-info-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid var(--border-color)}.bio-info-item:last-child{border-bottom:none}.bio-info-label{font-weight:500;color:var(--text-secondary)}.bio-info-value{font-weight:600;color:var(--text-primary)}.skills-list{display:flex;flex-direction:column;gap:1.25rem}.skill-item{display:flex;flex-direction:column;gap:.5rem}.skill-header{display:flex;justify-content:space-between}.skill-name{font-weight:500;color:var(--text-primary)}.skill-percent{font-weight:600;color:var(--text-secondary)}.skill-bar{width:100%;height:8px;background:var(--border-color);border-radius:10px;overflow:hidden}.skill-progress{height:100%;background:var(--text-primary);border-radius:10px;transition:width .5s ease}.hobbies-grid{display:flex;flex-wrap:wrap;gap:.75rem}.hobby-tag{background:var(--border-color);padding:.5rem 1rem;border-radius:20px;font-size:.9rem;color:var(--text-primary);transition:all .3s ease}.hobby-tag:hover{background:var(--text-primary);color:var(--bg-primary)}.bio-3ds-card{text-align:center}.bio-3ds-card h2 i{margin-right:.5rem}.ds-fc{color:var(--text-muted);font-size:.85rem;margin-bottom:.5rem}.ds-code{font-size:1.5rem;font-weight:700;color:var(--text-primary);letter-spacing:2px}.ds-note{color:var(--text-secondary);margin-top:1rem}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem}.project-card-link{text-decoration:none;color:inherit}.project-card{background:var(--project-card-bg);border-radius:16px;padding:1.5rem;transition:all .3s ease;height:100%}.project-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #0000001a}.project-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.project-header h3{font-size:1.1rem;color:var(--text-primary)}.project-header i{color:var(--text-muted)}.project-desc{color:var(--text-secondary);font-size:.9rem;margin-bottom:1rem;line-height:1.5}.project-stats{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:.75rem}.project-stat{display:flex;align-items:center;gap:.4rem;font-size:.85rem;color:var(--text-secondary)}.project-topics{display:flex;flex-wrap:wrap;gap:.5rem}.project-topic{background:var(--border-color);padding:.25rem .75rem;border-radius:12px;font-size:.8rem;color:var(--text-secondary)}.loading-text,.error-text,.empty-text{text-align:center;color:var(--text-secondary);padding:3rem}.error-hint{text-align:center;color:var(--text-muted);font-size:.9rem}.linktree-container{max-width:680px;margin:0 auto;text-align:center;padding:2rem 0}.linktree-profile{margin-bottom:3rem}.linktree-avatar{width:100px;height:100px;border-radius:50%;overflow:hidden;margin:0 auto 1.5rem;border:3px solid var(--text-primary)}.linktree-avatar img{width:100%;height:100%;object-fit:cover}.linktree-name{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.linktree-bio{color:var(--text-secondary);font-size:1rem}.linktree-links{display:flex;flex-direction:column;gap:1rem}.linktree-card{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-radius:12px;text-decoration:none;color:#fff;font-weight:600;transition:all .3s ease;position:relative}.linktree-card:hover{transform:scale(1.02);box-shadow:0 10px 30px #0003}.linktree-card-content{display:flex;align-items:center;gap:1rem}.linktree-card-content i{font-size:1.5rem}.linktree-note{font-size:.8rem;opacity:.8}.linktree-arrow{font-size:1rem}.linktree-footer{margin-top:3rem;color:var(--text-muted);font-size:.85rem}.links-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem}.link-card{background:var(--project-card-bg);padding:2rem;border-radius:16px;text-align:center;text-decoration:none;color:var(--text-primary);transition:all .3s ease}.link-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #0000001a}.link-card i{font-size:2.5rem;margin-bottom:1rem}.link-card span{display:block;font-weight:600}.link-note{color:var(--text-muted)!important;font-size:.85rem;margin-top:.5rem}.book-library{display:flex;flex-wrap:wrap;gap:3rem 2.5rem;justify-content:center;padding:1rem 0 3rem}.book-cover-wrapper{display:flex;flex-direction:column;align-items:center;gap:1.25rem;cursor:pointer;animation:bookFadeIn .5s ease both;width:160px}@keyframes bookFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.book-cover-card{position:relative;width:140px;height:200px;transform-style:preserve-3d;transform:perspective(800px) rotateY(-15deg);transition:transform .4s cubic-bezier(.34,1.56,.64,1);cursor:pointer}.book-cover-wrapper:hover .book-cover-card{transform:perspective(800px) rotateY(-5deg) translateY(-8px)}.book-spine{position:absolute;left:0;top:0;bottom:0;width:20px;background:linear-gradient(to right,color-mix(in srgb,var(--book-c1) 60%,black),var(--book-c1));border-radius:2px 0 0 2px;transform:translate(-20px) rotateY(-90deg);transform-origin:right center}.book-front{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,var(--book-c1),var(--book-c2));border-radius:2px 6px 6px 2px;box-shadow:4px 4px 20px #0000004d,inset -2px 0 8px #00000026;display:flex;flex-direction:column;overflow:hidden}.book-cover-img{width:100%;height:65%;object-fit:cover}.book-cover-placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:1rem}.book-cover-icon{font-size:2.5rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.book-genre-label{font-size:.65rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#fffc;background:#0003;padding:.2rem .6rem;border-radius:10px}.book-front-meta{padding:.75rem .75rem .5rem;background:#00000040;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.book-card-title{font-size:.75rem;font-weight:700;color:#fff;margin-bottom:.2rem;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.book-card-author{font-size:.65rem;color:#ffffffbf}.book-chapters-badge{display:inline-block;margin-top:.35rem;font-size:.6rem;background:#fff3;color:#fff;padding:.15rem .5rem;border-radius:8px}.book-read-btn{display:none}.book-meta-below{text-align:center;max-width:160px}.book-meta-title{font-size:.95rem;font-weight:600;color:var(--text-primary);margin-bottom:.2rem}.book-meta-author{font-size:.8rem;color:var(--text-muted);margin-bottom:.4rem}.book-meta-desc{font-size:.8rem;color:var(--text-secondary);line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.lit-page-content{max-width:1000px}.page-title{background:linear-gradient(135deg,var(--text-primary) 0%,var(--text-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.books-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(420px,1fr));gap:1.5rem;padding-bottom:4rem}.book-card{display:flex;flex-direction:row;align-items:stretch;gap:0;background:var(--card-bg);border-radius:16px;overflow:hidden;cursor:pointer;transition:transform .4s cubic-bezier(.34,1.56,.64,1),box-shadow .4s ease;animation:bookFadeIn .5s ease both;border:1px solid var(--border-color);position:relative;padding:0;min-height:190px}@keyframes bookFadeIn{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.book-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:16px;opacity:0;transition:opacity .4s ease;background:radial-gradient(ellipse at 30% 50%,rgba(255,255,255,.04) 0%,transparent 70%);pointer-events:none;z-index:1}.book-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 28px 60px #0000002e,0 8px 20px #0000001a}.book-card:hover:before{opacity:1}.book-card-cover{width:90px;min-height:100%;flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;position:relative;overflow:hidden}.book-card-cover:after{content:"";position:absolute;top:0;right:0;width:10px;height:100%;background:#0000002e;filter:blur(6px)}.book-cover-icon{font-size:2rem;color:#ffffffeb;filter:drop-shadow(0 2px 8px rgba(0,0,0,.35));z-index:1;transition:transform .4s ease}.book-card:hover .book-cover-icon{transform:scale(1.15) rotate(-3deg)}.book-fallback-genre{display:none}.book-card-info{display:flex;flex-direction:column;gap:.45rem;flex:1;min-width:0;padding:1.25rem 1.25rem 1rem}.book-card-genre{display:inline-flex;align-items:center;font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:.22rem .75rem;border-radius:20px;align-self:flex-start;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.book-card-title{font-size:1.2rem;font-weight:700;color:var(--text-primary);line-height:1.3;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;transition:color .25s ease}.book-card-author{display:flex;align-items:center;gap:.45rem;font-size:.8rem;color:var(--text-muted);margin:0;font-style:italic}.book-card-author i{font-size:.68rem;font-style:normal}.book-card-desc{font-size:.82rem;color:var(--text-secondary);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin:0;flex:1}.book-card-meta{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-top:auto;padding-top:.85rem;border-top:1px solid var(--border-color)}.book-card-chapters{display:flex;align-items:center;gap:.4rem;font-size:.73rem;color:var(--text-muted);background:var(--badge-bg);padding:.25rem .65rem;border-radius:20px}.book-card-chapters i{font-size:.65rem}.book-card-read{display:inline-flex;align-items:center;gap:.4rem;font-size:.78rem;font-weight:600;color:#fff;background:var(--text-primary);padding:.3rem .9rem;border-radius:20px;transition:all .25s ease;opacity:0;transform:translate(-6px)}.book-card-read i{font-size:.7rem}.book-card:hover .book-card-read{opacity:1;transform:translate(0)}.books-skeleton{display:grid;grid-template-columns:repeat(auto-fill,minmax(420px,1fr));gap:1.5rem;padding-bottom:3rem}.book-card-skeleton{height:190px;border-radius:16px;background:var(--border-color);animation:shimmer 1.5s infinite}@media (max-width: 900px){.books-list,.books-skeleton{grid-template-columns:1fr}}@media (max-width: 700px){.book-card-desc{-webkit-line-clamp:2}.book-card-cover{width:70px}}.library-skeleton{display:flex;gap:3rem 2.5rem;justify-content:center;flex-wrap:wrap;padding:1rem 0}.book-skeleton-card{display:flex;flex-direction:column;align-items:center;gap:.75rem;width:140px}.skeleton-cover{width:140px;height:200px;border-radius:6px;background:var(--border-color);animation:shimmer 1.5s infinite}.skeleton-line{height:12px;border-radius:6px;background:var(--border-color);animation:shimmer 1.5s infinite;align-self:stretch}@keyframes shimmer{0%,to{opacity:1}50%{opacity:.4}}.reader-section{padding:0;align-items:stretch}.book-reader{display:flex;flex-direction:column;height:100vh;height:100dvh;width:100%;background:var(--bg-primary);position:fixed;top:0;right:0;bottom:0;left:0;z-index:200}.reader-header{display:flex;align-items:center;gap:1rem;padding:.75rem 1.25rem;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:10;flex-shrink:0}.reader-back-btn{display:flex;align-items:center;gap:.5rem;padding:.45rem .85rem;border-radius:10px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);font-size:.82rem;font-weight:500;cursor:pointer;transition:all .22s ease;white-space:nowrap;font-family:inherit;flex-shrink:0}.reader-back-btn:hover{background:var(--hover-bg);color:var(--hover-text);border-color:var(--hover-bg);transform:translate(-2px)}.reader-back-label{display:inline}.reader-book-info{flex:1;display:flex;flex-direction:column;gap:.1rem;text-align:center;min-width:0}.reader-book-title{font-size:.9rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reader-book-author{font-size:.72rem;color:var(--text-muted);font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reader-toc-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-secondary);font-size:.9rem;cursor:pointer;transition:all .22s ease;flex-shrink:0}.reader-toc-btn:hover{background:var(--hover-bg);color:var(--hover-text);border-color:var(--hover-bg)}.reader-progress-bar{height:3px;background:var(--border-color);flex-shrink:0;position:relative;overflow:hidden}.reader-progress-fill{height:100%;border-radius:0 2px 2px 0;transition:width .4s cubic-bezier(.4,0,.2,1)}.reader-body{display:flex;flex:1;overflow:hidden;position:relative}.chapter-sidebar{width:260px;flex-shrink:0;border-right:1px solid var(--border-color);overflow-y:auto;padding:0;background:var(--bg-secondary);display:flex;flex-direction:column;transition:transform .3s cubic-bezier(.4,0,.2,1)}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1rem .75rem;border-bottom:1px solid var(--border-color);flex-shrink:0}.sidebar-close-btn{display:none;width:30px;height:30px;border-radius:8px;border:none;background:var(--border-color);color:var(--text-secondary);cursor:pointer;align-items:center;justify-content:center;font-size:.85rem;transition:all .2s ease}.sidebar-close-btn:hover{background:var(--hover-bg);color:var(--hover-text)}.sidebar-title{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--text-muted);margin:0;display:flex;align-items:center;gap:.45rem}.sidebar-loading{display:flex;flex-direction:column;gap:.75rem;padding:1rem}.chapter-list{display:flex;flex-direction:column;gap:0;padding:.5rem;overflow-y:auto;flex:1}.chapter-item{display:flex;align-items:center;gap:.65rem;padding:.65rem .85rem;border-radius:10px;border:none;background:none;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;text-align:left;width:100%;font-size:.82rem;font-family:inherit;position:relative}.chapter-item:before{content:"";position:absolute;left:4px;top:20%;height:60%;width:3px;border-radius:3px;background:transparent;transition:background .22s ease}.chapter-item:hover{background:var(--border-color);color:var(--text-primary)}.chapter-item.active{background:var(--badge-bg);color:var(--text-primary);font-weight:600}.chapter-item.active:before{background:var(--text-primary)}.chapter-num{font-size:.62rem;font-weight:700;opacity:.4;flex-shrink:0;font-variant-numeric:tabular-nums;min-width:1.5rem}.chapter-item.active .chapter-num{opacity:.7}.chapter-name{line-height:1.35;flex:1}.chapter-active-dot{font-size:.45rem;color:var(--text-muted);flex-shrink:0;opacity:.6}.sidebar-backdrop{display:none}.chapter-content{flex:1;overflow-y:auto;padding:4rem 5rem;transition:opacity .25s ease;background:var(--bg-primary) radial-gradient(ellipse at top center,rgba(255,255,255,.03) 0%,transparent 60%)}[data-theme=dark] .chapter-content{background:var(--bg-primary) radial-gradient(ellipse at top center,rgba(255,255,255,.02) 0%,transparent 60%)}.chapter-content.fading{opacity:0}.content-skeleton{display:flex;flex-direction:column;gap:1rem;max-width:680px;margin:0 auto}.chapter-header-label{margin-bottom:3rem;padding-bottom:2rem;border-bottom:1px solid var(--border-color);max-width:680px;margin-left:auto;margin-right:auto}.chapter-num-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--text-muted);display:block;margin-bottom:.65rem}.chapter-display-title{font-size:2.1rem;font-weight:700;color:var(--text-primary);line-height:1.25;letter-spacing:-.02em}.markdown-body{max-width:680px;margin:0 auto;line-height:1.9;color:var(--text-secondary);font-size:1.06rem;font-family:Georgia,Times New Roman,serif}.markdown-body h1,.markdown-body h2,.markdown-body h3,.markdown-body h4{color:var(--text-primary);margin:2.5rem 0 1rem;line-height:1.3;font-family:Inter,sans-serif;letter-spacing:-.015em}.markdown-body h1{font-size:1.75rem;font-weight:700}.markdown-body h2{font-size:1.4rem;font-weight:700}.markdown-body h3{font-size:1.15rem;font-weight:600}.markdown-body p{margin-bottom:1.4rem;text-indent:1.5em}.markdown-body p:first-of-type{text-indent:0}.markdown-body strong{color:var(--text-primary);font-weight:700}.markdown-body em{font-style:italic;color:var(--text-primary)}.markdown-body blockquote{border-left:3px solid var(--text-muted);padding:1rem 1.75rem;margin:2rem 0;color:var(--text-muted);font-style:italic;background:var(--bg-secondary);border-radius:0 10px 10px 0;font-size:1.08rem;line-height:1.8}.markdown-body code{background:var(--bg-secondary);padding:.18rem .5rem;border-radius:4px;font-size:.9em;font-family:SFMono-Regular,Consolas,monospace;color:var(--text-primary)}.markdown-body pre{background:var(--bg-secondary);border-radius:12px;padding:1.5rem;overflow-x:auto;margin:2rem 0;border:1px solid var(--border-color)}.markdown-body hr{border:none;border-top:1px solid var(--border-color);margin:2.5rem 0;position:relative}.markdown-body hr:after{content:"✦";position:absolute;left:50%;top:-.7em;transform:translate(-50%);background:var(--bg-primary);padding:0 .75rem;color:var(--text-muted);font-size:.8rem}.markdown-body ul,.markdown-body ol{padding-left:1.75rem;margin-bottom:1.4rem}.markdown-body li{margin-bottom:.5rem;line-height:1.7}.reader-footer{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.25rem;border-top:1px solid var(--border-color);background:var(--bg-secondary);gap:1rem;flex-shrink:0}.reader-nav-btn{display:flex;align-items:center;gap:.45rem;padding:.6rem 1.1rem;border-radius:10px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);font-size:.82rem;font-weight:500;cursor:pointer;transition:all .22s ease;font-family:inherit;flex-shrink:0}.reader-nav-btn:hover:not(:disabled){background:var(--hover-bg);color:var(--hover-text);border-color:var(--hover-bg);transform:translateY(-1px);box-shadow:0 4px 12px #0000001f}.reader-nav-btn:disabled{opacity:.28;cursor:not-allowed}.reader-nav-label{display:inline}.reader-chapter-indicator{display:flex;align-items:baseline;gap:.3rem;font-variant-numeric:tabular-nums}.reader-chapter-current{font-size:1.35rem;font-weight:700;color:var(--text-primary);line-height:1}.reader-chapter-sep,.reader-chapter-total{font-size:.85rem;color:var(--text-muted)}@media (max-width: 768px){.chapter-sidebar{position:fixed;top:0;right:0;bottom:0;left:0;width:80vw;max-width:300px;border-right:1px solid var(--border-color);z-index:300;transform:translate(-100%);box-shadow:4px 0 32px #0000002e}.chapter-sidebar.sidebar-open{transform:translate(0)}.sidebar-close-btn{display:flex}.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:299;animation:fadeIn .2s ease}.chapter-content{padding:1.75rem 1.25rem 2rem}.chapter-header-label{max-width:100%;margin-bottom:2rem;padding-bottom:1.25rem}.chapter-display-title{font-size:1.6rem}.markdown-body{max-width:100%;font-size:1rem;line-height:1.8}.reader-header{padding:.65rem 1rem;gap:.65rem}.reader-back-label{display:none}.reader-back-btn{padding:.45rem .65rem;width:36px;height:36px;justify-content:center}.reader-footer{padding:.65rem 1rem}.reader-nav-label{display:none}.reader-nav-btn{padding:.6rem .85rem;min-width:44px;justify-content:center}.reader-chapter-current{font-size:1.1rem}}.gallery-page-content{max-width:1200px}.gallery-filters{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;margin-bottom:2.5rem}.gallery-filter-btn{padding:.45rem 1.1rem;border-radius:20px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-secondary);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease;font-family:inherit}.gallery-filter-btn:hover{border-color:var(--text-primary);color:var(--text-primary)}.gallery-filter-btn.active{background:var(--text-primary);color:var(--bg-primary);border-color:var(--text-primary)}.gallery-masonry{columns:4 220px;column-gap:1rem;margin-bottom:1.5rem}.gallery-masonry-item{position:relative;break-inside:avoid;margin-bottom:1rem;border-radius:12px;overflow:hidden;cursor:pointer;animation:galleryFadeIn .45s ease both;background:var(--bg-secondary)}@keyframes galleryFadeIn{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.gallery-masonry-item img{width:100%;height:auto;display:block;transition:transform .45s cubic-bezier(.25,.46,.45,.94)}.gallery-masonry-item:hover img{transform:scale(1.06)}.gallery-item-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,#000c,#0000008c,#00000040,#00000014,#0000 80%);opacity:0;transition:opacity .3s ease;display:flex;flex-direction:column;justify-content:flex-end;padding:1rem}.gallery-masonry-item:hover .gallery-item-overlay{opacity:1}.gallery-item-info{display:flex;flex-direction:column;gap:.25rem}.gallery-item-name{font-size:.9rem;font-weight:600;color:#fff;line-height:1.3}.gallery-item-meta{font-size:.75rem;color:#ffffffb3;display:flex;align-items:center;gap:.35rem}.gallery-zoom-icon{position:absolute;top:.75rem;right:.75rem;width:32px;height:32px;background:#ffffff26;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.85rem;transform:scale(.8);transition:transform .2s ease}.gallery-masonry-item:hover .gallery-zoom-icon{transform:scale(1)}.gallery-skeleton-item{break-inside:avoid;margin-bottom:1rem;border-radius:12px;background:var(--border-color);animation:shimmer 1.5s infinite;width:100%}.gallery-empty{text-align:center;padding:5rem 2rem;display:flex;flex-direction:column;align-items:center;gap:1rem}.gallery-empty-icon-fa{font-size:3rem;color:var(--text-muted)}.gallery-empty p{color:var(--text-secondary);max-width:400px;line-height:1.6}.gallery-count{text-align:center;color:var(--text-muted);font-size:.85rem;margin-bottom:2rem}.gallery-albums{display:flex;flex-direction:column;gap:3.5rem}.gallery-album{display:flex;flex-direction:column;gap:1.25rem}.gallery-album-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:.75rem;border-bottom:2px solid var(--border-color)}.gallery-album-title{font-size:1.35rem;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:.65rem;margin:0}.gallery-album-title i{color:var(--text-secondary);font-size:1.1rem}.gallery-album-count{font-size:.82rem;color:var(--text-muted);font-weight:400;white-space:nowrap}.gallery-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000eb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease;gap:1.5rem;padding:1.5rem}.gallery-lightbox-content{position:relative;display:flex;flex-direction:column;align-items:center;max-width:900px;width:100%;gap:0}.lightbox-close-btn{position:absolute;top:-16px;right:-16px;width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,.2);background:#ffffff1a;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;transition:all .2s ease;z-index:2}.lightbox-close-btn:hover{background:#ffffff40;transform:scale(1.1)}.lightbox-img-wrap{width:100%;border-radius:12px 12px 0 0;overflow:hidden;background:transparent;min-height:200px;display:flex;align-items:center;justify-content:center;position:relative}.lightbox-img-wrap img{width:100%;max-height:72vh;object-fit:contain;display:block;opacity:0;transition:opacity .3s ease}.lightbox-img-wrap.loaded img{opacity:1}.lightbox-spinner{position:absolute;width:32px;height:32px;border:3px solid rgba(255,255,255,.15);border-top-color:#ffffffb3;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.lightbox-footer{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.85rem 1rem;background:#ffffff0d;border-radius:0 0 12px 12px;gap:1rem}.lightbox-footer-info{display:flex;flex-direction:column;gap:.2rem}.lightbox-name{font-size:.95rem;font-weight:600;color:#fff}.lightbox-sub{font-size:.78rem;color:#ffffff80}.lightbox-counter{font-size:.8rem;color:#ffffff80;white-space:nowrap}.lightbox-nav-btn{flex-shrink:0;width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.2);background:#ffffff14;color:#fff;font-size:1.1rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;align-self:center}.lightbox-nav-btn:hover:not(:disabled){background:#fff3;transform:scale(1.1)}.lightbox-nav-btn:disabled{opacity:.2;cursor:not-allowed}@media (max-width: 768px){.gallery-masonry{columns:2 150px}.lightbox-nav-btn{display:none}.gallery-lightbox{padding:1rem}}.main-footer{padding:3rem 2rem;text-align:center;color:var(--text-muted);border-top:1px solid var(--border-color)}@media (max-width: 968px){.hero-content{flex-direction:column-reverse;text-align:center}.hero-text h1{font-size:2.5rem}.hero-image img{max-width:300px}.tags,.hero-buttons,.social-links{justify-content:center}.navbar{padding:.5rem 1rem;gap:1rem;font-size:.8rem}}@media (max-width: 480px){.hero-text h1{font-size:2rem}.hero-section{padding:6rem 1rem 3rem}.hero-image img{max-width:200px;border-radius:15px}.bio-content{padding:1rem}.bio-avatar img{max-width:120px!important}.mobile-menu-toggle{display:flex!important;position:fixed;top:1rem;left:1rem;z-index:200;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text-primary);font-size:1.5rem;cursor:pointer;padding:.5rem;border-radius:0;transition:opacity .3s ease}.navbar{display:none}}.mobile-menu-toggle{display:none}.mobile-menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:999;opacity:0;pointer-events:none;transition:opacity .3s ease}.mobile-menu-overlay.open{opacity:1;pointer-events:all}.mobile-menu{position:fixed;top:0;right:0;width:80vw;max-width:320px;height:100vh;background:var(--bg-primary);z-index:1000;transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:-4px 0 20px #00000026}.mobile-menu.open{transform:translate(0)}.mobile-menu-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--border-color)}.mobile-menu-header h3{margin:0;font-size:1.25rem;color:var(--text-primary)}.mobile-menu-close{background:none;border:none;color:var(--text-primary);font-size:1.5rem;cursor:pointer;padding:.5rem;border-radius:8px;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.mobile-menu-close:hover{background:var(--hover-bg);color:var(--hover-text)}.mobile-menu-items{flex:1;overflow-y:auto;padding:1rem 0}.mobile-menu-items a{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;text-decoration:none;color:var(--text-primary);font-size:1.1rem;font-weight:500;transition:all .2s ease;border-left:3px solid transparent}.mobile-menu-items a:hover,.mobile-menu-items a.active{background:var(--hover-bg);color:var(--hover-text);border-left-color:var(--hover-bg)}.mobile-menu-items a i{width:24px;text-align:center;font-size:1.2rem}.mobile-menu-footer{padding:1.5rem;border-top:1px solid var(--border-color);display:flex;gap:1rem;align-items:center;justify-content:center}.mobile-menu-footer .theme-toggle,.mobile-menu-footer .language-toggle{font-size:1.5rem;padding:.75rem}@media (hover: none) and (pointer: coarse){a,button{min-height:44px;min-width:44px}.mobile-menu-items a{padding:1.25rem 1.5rem}}@media (max-width: 480px){.page-section{padding:5rem .75rem 2rem}.page-title{font-size:2rem}.page-subtitle{font-size:1.25rem}body{font-size:14px}html,body{overflow-x:hidden;-webkit-text-size-adjust:100%}img{max-width:100%;height:auto}.project-card,.bio-info-card,.bio-skills-card,.bio-hobbies-card,.bio-3ds-card{padding:1.25rem}table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}pre,code{font-size:.85rem;word-wrap:break-word;white-space:pre-wrap}input,textarea,select{font-size:16px!important}.hero-social-buttons{flex-direction:column;gap:.75rem}.hero-social-btn{width:100%;justify-content:center}}@media (max-width: 768px){.bio-grid{grid-template-columns:1fr;gap:1.5rem}.software-grid{grid-template-columns:1fr}.resume-section{margin-bottom:2rem}.lightbox-nav-btn{width:50px;height:50px;font-size:1.5rem}}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes likebeat{0%{transform:scale(1)}25%{transform:scale(1.35)}50%{transform:scale(1.1)}75%{transform:scale(1.25)}to{transform:scale(1)}}.like-btn{display:inline-flex;align-items:center;gap:.35rem;border:none;background:none;cursor:pointer;font-family:inherit;transition:all .2s ease;line-height:1;padding:0}.like-btn i{transition:transform .15s ease,color .2s ease}.like-btn.liked i{animation:likebeat .4s ease;color:#f43f5e}.like-btn.loading{opacity:.6;pointer-events:none}.like-btn--card{padding:.3rem .7rem;border-radius:20px;border:1px solid var(--border-color);background:var(--bg-primary);font-size:.78rem;font-weight:500;color:var(--text-muted);gap:.4rem}.like-btn--card:hover{border-color:#f43f5e;color:#f43f5e;background:#f43f5e0f;transform:scale(1.05)}.like-btn--card.liked{border-color:#f43f5e;color:#f43f5e;background:#f43f5e14}.like-btn--card .like-count{font-size:.72rem;font-weight:600;font-variant-numeric:tabular-nums}.like-btn--overlay{padding:.4rem .75rem;border-radius:20px;background:#ffffff26;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;font-size:.8rem;font-weight:600;gap:.4rem;border:1px solid rgba(255,255,255,.2);align-self:flex-start;margin-top:.35rem}.like-btn--overlay:hover{background:#f43f5e66;border-color:#f43f5e99}.like-btn--overlay.liked{background:#f43f5e59;border-color:#f43f5e80}.like-btn--overlay i{color:#fff}.like-btn--overlay.liked i{color:#fda4af}.like-btn--overlay .like-count{font-size:.75rem;font-variant-numeric:tabular-nums}.like-btn--reader{padding:.4rem .9rem;border-radius:20px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-secondary);font-size:.82rem;font-weight:500;gap:.4rem}[data-theme=dark] .like-btn--reader{background:#ffffff0f;border-color:#ffffff26;color:#ffffffb3}.like-btn--reader:hover{border-color:#f43f5e;color:#f43f5e;background:#f43f5e0f}.like-btn--reader.liked{border-color:#f43f5e;color:#f43f5e;background:#f43f5e14}.like-btn--reader .like-count{font-size:.78rem;font-variant-numeric:tabular-nums;font-weight:600}.book-card-actions{display:flex;align-items:center;gap:.5rem}.reader-header-right,.lightbox-footer-right{display:flex;align-items:center;gap:.75rem;flex-shrink:0}
