.home{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:100px 20px 60px;position:relative;overflow:hidden}.home:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 50%,rgba(93,155,155,.08) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(155,168,200,.08) 0%,transparent 50%);animation:bgPulse 15s ease-in-out infinite;pointer-events:none}.home-container{max-width:1100px;width:100%;margin:0 auto;position:relative;z-index:1;display:flex;flex-direction:column;align-items:center}@media (min-width: 769px){.home-container{position:relative}.home-container:before,.home-container:after{content:"";position:fixed;top:calc(60px + (100vh - 60px)/2);transform:translateY(-50%);height:65vh;min-height:600px;max-height:65vh;width:1px;background:#ffffff14;z-index:-1}.home-container:before{left:calc((100vw - 1100px)/2)}.home-container:after{right:calc((100vw - 1100px)/2)}}.logo-section{margin-bottom:60px;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;max-width:900px;position:relative;overflow:visible}.logo-row{display:flex;align-items:center;justify-content:center;gap:30px;width:100%}.tagline{position:absolute;bottom:10px;right:calc(50% - 250px);font-size:1.1rem;font-style:italic;color:#7ab8b8e6;margin:0;text-align:right;font-weight:300;letter-spacing:.3px;white-space:nowrap;overflow:hidden;border-right:2px solid rgba(122,184,184,.9);width:0;animation:typing 12s steps(44) 1s infinite,blink .75s step-end infinite}.logo-section{position:relative}@media (min-width: 769px){.logo-wrapper .tagline{display:none}}.logo-section:after{content:"I build things, usually by writing things.";position:absolute;bottom:10px;right:calc(50% - 250px);font-size:1.1rem;font-style:italic;color:#7ab8b8e6;margin:0;text-align:right;font-weight:300;letter-spacing:.3px;white-space:nowrap;overflow:hidden;border-right:2px solid rgba(122,184,184,.9);width:0;animation:typing 12s steps(44) 1s infinite,blink .75s step-end infinite}@keyframes typing{0%,5%{width:0}40%,80%{width:100%}to{width:0}}@keyframes blink{50%{border-color:transparent}}.profile-image{flex-shrink:0}.image-placeholder{width:180px;height:180px;border-radius:50%;background:linear-gradient(135deg,#5d9b9b33,#7ab8b833);border:3px solid rgba(93,155,155,.4);box-shadow:0 8px 32px #5d9b9b4d,inset 0 2px 8px #ffffff1a;display:flex;align-items:center;justify-content:center;overflow:hidden;animation:fadeInScale .8s cubic-bezier(.4,0,.2,1);user-select:none;-webkit-user-select:none}.image-placeholder img{width:100%;height:100%;object-fit:cover;user-select:none;-webkit-user-select:none;-webkit-user-drag:none;pointer-events:none}.logo-wrapper{display:flex;flex-direction:row;align-items:center;gap:0;flex:1}.logo-container{display:flex;justify-content:flex-start;align-items:center;flex:1;position:relative}.logo{width:100%;max-width:650px;height:auto;filter:drop-shadow(0 4px 12px rgba(93,155,155,.5)) drop-shadow(0 0 30px rgba(122,184,184,.3));-webkit-user-select:none;user-select:none;animation:fadeInScale .8s cubic-bezier(.4,0,.2,1)}.logo-cat-container{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:5}.logo-letter,.x-line{transform-origin:center}.x-line-1,.x-line-1-inner{animation:xShake1 8s ease-in-out infinite}.x-line-2,.x-line-2-inner{animation:xShake2 8s ease-in-out infinite;animation-delay:.5s}@keyframes xShake1{0%,to{transform:translate(0)}25%{transform:translate(.5px)}50%{transform:translate(0)}75%{transform:translate(-.5px)}}@keyframes xShake2{0%,to{transform:translate(0)}25%{transform:translate(-.5px)}50%{transform:translate(0)}75%{transform:translate(.5px)}}.logo-l{animation:floatL 3s ease-in-out infinite;animation-delay:0s}.logo-u{animation:floatU 3.5s ease-in-out infinite;animation-delay:.2s}.logo-y{animation:floatY 3.2s ease-in-out infinite;animation-delay:.4s}.logo-r{animation:floatR 3.3s ease-in-out infinite;animation-delay:.6s}.logo-e{animation:floatE 3.4s ease-in-out infinite;animation-delay:.8s}.logo-n{animation:floatN 3.1s ease-in-out infinite;animation-delay:1s}@keyframes floatL{0%,to{transform:translate(20px,35px) translateY(0)}50%{transform:translate(20px,35px) translateY(-2px)}}@keyframes floatU{0%,to{transform:translate(60px,50px) translateY(0)}50%{transform:translate(60px,50px) translateY(-1.5px)}}@keyframes floatY{0%,to{transform:translate(205px,50px) translateY(0)}50%{transform:translate(205px,50px) translateY(-2px)}}@keyframes floatR{0%,to{transform:translate(265px,50px) translateY(0)}50%{transform:translate(265px,50px) translateY(-1.8px)}}@keyframes floatE{0%,to{transform:translate(320px,50px) translateY(0)}50%{transform:translate(320px,50px) translateY(-1.5px)}}@keyframes floatN{0%,to{transform:translate(385px,50px) translateY(0)}50%{transform:translate(385px,50px) translateY(-2px)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.stars-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1;overflow:hidden}.lightning-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:2}.lightning{position:absolute;width:50px;height:40%;top:30%;opacity:0;animation:lightningStrike 10s infinite;filter:drop-shadow(0 0 10px rgba(212,165,116,.8)) drop-shadow(0 0 20px rgba(193,122,77,.6)) drop-shadow(0 0 30px rgba(122,155,118,.4))}@keyframes lightningStrike{0%,to{opacity:0}49%{opacity:0}50%{opacity:.8}51%{opacity:.3}52%{opacity:1}53%{opacity:.5}54%{opacity:.9}55%{opacity:.2}56%{opacity:0}}.intro{margin-bottom:50px;font-size:1.15rem;line-height:1.9;text-align:left;color:#d1d5db;max-width:800px;width:100%}.intro p{font-weight:400}.flag-icon{display:inline-block;width:24px;height:16px;vertical-align:middle;margin:0 4px;border:1px solid rgba(255,255,255,.2);border-radius:2px}.links{font-size:1rem;line-height:1.9;max-width:800px;width:100%}.links ul{list-style:none}.links li{margin-bottom:16px;position:relative;padding-left:28px}.links li:before{content:"→";position:absolute;left:0;color:#9ba8c8;font-size:1.1rem}.links a{color:#7ab8b8;text-decoration:none;position:relative;transition:all .3s ease;font-weight:500}.links a:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:2px;background:linear-gradient(90deg,#5d9b9b,#7ab8b8,#9ba8c8);transition:width .3s ease}.links a:hover{color:#9ba8c8}.links a:hover:after{width:100%}.highlight{background:linear-gradient(135deg,#7ab8b8,#9ba8c8,#7b8aab);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:600;padding:0 2px}.name-highlight{background:linear-gradient(135deg,#7ab8b8,#9ba8c8,#7b8aab);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:700;font-size:1.05em}.particle{position:absolute;top:-10px;width:2px;height:2px;background:#d4a57499;border-radius:50%;box-shadow:0 0 4px #d4a574cc,0 0 8px #c17a4d66;animation:particleFall linear infinite}.particle:nth-child(2n){background:#7a9b7699;box-shadow:0 0 4px #7a9b76cc,0 0 8px #7a9b7666}@media (max-width: 768px){.home{padding:80px 0 40px;min-height:100vh}.home-container{padding:0;margin:0;max-width:100%;width:100%}.home-container:before,.home-container:after{display:none}.logo-section{margin-bottom:50px;width:100%}.logo-row{flex-direction:row;gap:20px;align-items:flex-start;width:100%}.profile-image{flex-shrink:0}.image-placeholder{width:120px;height:120px;border-width:2px}.logo-wrapper{flex:1;min-width:0;display:flex;flex-direction:column;align-items:flex-start;gap:10px}.logo-container{width:100%;max-width:100%;display:flex;justify-content:flex-start;align-items:center;position:relative}.logo{max-width:100%;width:100%;height:auto;display:block}.logo-section:after{display:none}.logo-wrapper .tagline{display:block;position:static;text-align:left;margin-top:10px;font-size:.9rem;width:100%;border-right:none;animation:none!important;white-space:normal;padding:0;color:#7ab8b8d9;overflow:visible}.intro{font-size:1rem;margin-bottom:45px;text-align:center;padding:0 20px;line-height:1.8}.intro p{margin:0;word-wrap:break-word}.flag-icon{width:22px;height:15px;margin:0 3px}.links{font-size:.95rem;text-align:left;padding:0 20px;line-height:1.85}.logo-section{padding:0 20px}.links ul{margin:0;padding:0}.links li{margin-bottom:20px;padding-left:26px;word-wrap:break-word}.links li:before{font-size:1.1rem;left:2px}.links a{display:inline-block;padding:2px 0;touch-action:manipulation}.logo-letter,.x-line{animation:none!important}}@media (max-width: 480px){.home{padding:70px 0 30px}.home-container{padding:0;margin:0;width:100%}.home-container:before,.home-container:after{display:none}.logo-section{margin-bottom:40px}.logo-row{gap:15px}.image-placeholder{width:100px;height:100px}.logo-wrapper{gap:10px}.logo-wrapper .tagline{display:block;position:static;text-align:left;margin-top:8px;font-size:.85rem;width:100%;border-right:none;animation:none!important;white-space:normal;padding:0;color:#7ab8b8d9;overflow:visible}.logo-section:after{display:none}.intro{font-size:.95rem;margin-bottom:35px;line-height:1.75;padding:0 15px}.intro p{text-align:center}.flag-icon{width:20px;height:14px;margin:0 2px}.links{font-size:.9rem;padding:0 15px;line-height:1.8}.logo-section{padding:0 15px}.links li{margin-bottom:18px;padding-left:22px}.links li:before{font-size:1rem;left:0}.links a{padding:3px 0;min-height:44px;display:inline-flex;align-items:center}.highlight{padding:0 1px}.name-highlight{font-size:1.03em}.logo-letter,.x-line{animation:none!important}}.oneko-cat{width:24px;height:24px;position:absolute;pointer-events:none;background-size:800% 400%;background-repeat:no-repeat;z-index:5;filter:drop-shadow(0 2px 8px rgba(122,184,184,.8)) drop-shadow(0 0 16px rgba(122,184,184,.5));transform-origin:center;will-change:transform,left,top;top:0;left:0}@media (max-width: 768px){.oneko-cat{display:none!important}}.words{min-height:100vh;padding:100px 20px 60px;position:relative;overflow:hidden}.words:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 50%,rgba(93,155,155,.08) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(122,184,184,.08) 0%,transparent 50%);animation:bgPulse 15s ease-in-out infinite;pointer-events:none}.words-container{max-width:1100px;width:100%;margin:0 auto;position:relative;z-index:1;display:flex;flex-direction:column;align-items:center}@media (min-width: 769px){.words-container{position:relative}.words-container:before,.words-container:after{content:"";position:fixed;top:calc(60px + (100vh - 60px)/2);transform:translateY(-50%);height:65vh;min-height:600px;max-height:65vh;width:1px;background:#ffffff14;z-index:-1}.words-container:before{left:calc((100vw - 1100px)/2)}.words-container:after{right:calc((100vw - 1100px)/2)}}.filter-section{margin-bottom:50px;max-width:800px;width:100%}.filter-label{display:block;margin-bottom:15px;font-size:.95rem;color:#9ca3af;text-transform:uppercase;letter-spacing:.05em}.tag-filters{display:flex;flex-wrap:wrap;gap:10px}.tag-filter{padding:10px 20px;background:#ffffff0d;border:2px solid rgba(255,255,255,.1);border-radius:8px;color:#e5e7eb;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);text-transform:uppercase;letter-spacing:.5px}.tag-filter:hover{background:#ffffff1a;border-color:#5d9b9b80;transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.tag-filter.active{background:linear-gradient(135deg,#5d9b9b,#7ab8b8,#9ba8c8);border-color:#7ab8b8;color:#fff;box-shadow:0 4px 16px #7ab8b866}.posts-list{display:flex;flex-direction:column;gap:40px;max-width:800px;width:100%}.post-item{display:flex;gap:20px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.05)}.post-item:last-child{border-bottom:none}.post-date{font-size:.9rem;color:#9ca3af;font-family:Courier New,Courier,monospace;min-width:100px;flex-shrink:0}.post-content{flex:1}.post-title{font-size:1.5rem;font-weight:700;margin-bottom:8px;line-height:1.3}.post-title a{color:#e5e7eb;text-decoration:none;transition:color .2s}.post-title a:hover{color:#9ba8c8}.post-tags{display:inline-flex;gap:8px;margin-bottom:10px;margin-left:12px}.post-tag{display:inline-block;padding:5px 12px;background:linear-gradient(135deg,#5d9b9b33,#9ba8c833);border:1px solid rgba(122,184,184,.4);border-radius:6px;font-size:.75rem;font-weight:700;color:#9ba8c8;text-transform:uppercase;letter-spacing:.5px}.post-subtitle{font-size:1rem;line-height:1.6;color:#d1d5db}@media (max-width: 768px){.words{padding:90px 0 40px}.words-container{padding:0;margin:0;max-width:100%;width:100%}.words-container:before,.words-container:after{display:none}.filter-section,.posts-list{padding:0 20px}.filter-section{margin-bottom:40px}.filter-label{font-size:.9rem;margin-bottom:12px}.tag-filters{gap:8px}.tag-filter{padding:8px 16px;font-size:.85rem}.posts-list{gap:30px}.post-item{flex-direction:column;gap:10px;padding-bottom:30px}.post-date{min-width:auto;font-size:.85rem}.post-title{font-size:1.25rem;line-height:1.4}.post-tags{margin-left:0;margin-bottom:8px}.post-tag{font-size:.7rem;padding:4px 10px}.post-subtitle{font-size:.95rem}}@media (max-width: 480px){.words{padding:80px 0 30px}.words-container{padding:0;margin:0;width:100%}.words-container:before,.words-container:after{display:none}.filter-section,.posts-list{padding:0 15px}.filter-section{margin-bottom:30px}.filter-label{font-size:.85rem;margin-bottom:10px}.tag-filter{padding:7px 14px;font-size:.8rem}.posts-list{gap:25px}.post-item{padding-bottom:25px}.post-date{font-size:.8rem}.post-title{font-size:1.1rem}.post-tag{font-size:.65rem;padding:3px 8px}.post-subtitle{font-size:.9rem;line-height:1.5}}.blog-post-page{min-height:100vh;padding:100px 20px 40px;position:relative;overflow:hidden}.blog-post-page:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 50%,rgba(212,165,116,.05) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(193,122,77,.05) 0%,transparent 50%),radial-gradient(circle at 40% 20%,rgba(122,155,118,.04) 0%,transparent 40%);animation:bgPulse 15s ease-in-out infinite;pointer-events:none}@keyframes bgPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}.particles{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden;pointer-events:none;z-index:0}.blog-post-container{max-width:1100px;width:100%;margin:0 auto;position:relative;z-index:1;display:flex;flex-direction:column;align-items:center}@media (min-width: 769px){.blog-post-container{position:relative}.blog-post-container:before,.blog-post-container:after{content:"";position:fixed;top:calc(60px + (100vh - 60px)/2);transform:translateY(-50%);height:65vh;min-height:600px;max-height:65vh;width:1px;background:#ffffff14;z-index:-1}.blog-post-container:before{left:calc((100vw - 1100px)/2)}.blog-post-container:after{right:calc((100vw - 1100px)/2)}}.blog-post{max-width:800px;width:100%}.blog-post-title{font-size:2.5rem;font-weight:800;line-height:1.2;margin-bottom:20px;color:#f9fafb}.blog-post-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.1)}.blog-post-date{font-size:.95rem;color:#9ca3af}.edit-link{font-size:.9rem;color:#9ba8c8;text-decoration:underline}.blog-post-tldr{background:linear-gradient(135deg,#5d9b9b1a,#9ba8c81a);border-left:3px solid #7AB8B8;padding:20px;margin-bottom:40px;border-radius:4px;line-height:1.7}.blog-post-tldr strong{color:#9ba8c8}.blog-post-content{font-size:1.05rem;line-height:1.8;color:#e5e7eb}.blog-post-content h2{font-size:1.8rem;font-weight:700;margin-top:40px;margin-bottom:20px;color:#f9fafb;border-bottom:2px solid rgba(212,165,116,.3);padding-bottom:10px}.blog-post-content h3{font-size:1.4rem;font-weight:600;margin-top:32px;margin-bottom:16px;color:#f3f4f6}.blog-post-content p{margin-bottom:20px}.blog-post-content ul{margin:20px 0;padding-left:30px;list-style:none}.blog-post-content ul li{margin-bottom:12px;position:relative;padding-left:10px}.blog-post-content ul li:before{content:"▸";position:absolute;left:-20px;color:#9ba8c8}.blog-post-content strong{color:#f9fafb;font-weight:600}.blog-post-content a{color:#7ab8b8;text-decoration:underline}.blog-post-content a:hover{color:#9ba8c8}.blog-post-content img{width:100%;height:auto;border-radius:8px;margin:30px 0;border:1px solid rgba(255,255,255,.1)}.blog-post-content code{background:#ffffff1a;padding:2px 6px;border-radius:4px;font-size:.9em;font-family:Courier New,Courier,monospace}.blog-post-content pre{background:#0000004d;padding:20px;border-radius:8px;overflow-x:auto;margin:20px 0;border:1px solid rgba(255,255,255,.1)}.blog-post-content pre code{background:none;padding:0}@media (max-width: 768px){.blog-post-page{padding:90px 0 40px}.blog-post-container{padding:0;margin:0;max-width:100%;width:100%}.blog-post-container:before,.blog-post-container:after{display:none}.blog-post{padding:0 20px}.blog-post-title{font-size:1.8rem;line-height:1.3;margin-bottom:16px}.blog-post-meta{flex-direction:column;align-items:flex-start;gap:10px;margin-bottom:24px;padding-bottom:16px}.blog-post-date{font-size:.9rem}.edit-link{font-size:.85rem}.blog-post-tldr{padding:16px;margin-bottom:30px;font-size:.95rem}.blog-post-content{font-size:1rem;line-height:1.7}.blog-post-content h2{font-size:1.5rem;margin-top:32px;margin-bottom:16px;padding-bottom:8px}.blog-post-content h3{font-size:1.25rem;margin-top:28px;margin-bottom:12px}.blog-post-content p{margin-bottom:16px}.blog-post-content ul{margin:16px 0;padding-left:24px}.blog-post-content ul li{margin-bottom:10px;padding-left:8px}.blog-post-content img{margin:24px 0}.blog-post-content pre{padding:16px;margin:16px 0;font-size:.9rem}}@media (max-width: 480px){.blog-post-page{padding:80px 0 30px}.blog-post-container{padding:0;margin:0;width:100%}.blog-post-container:before,.blog-post-container:after{display:none}.blog-post{padding:0 15px}.blog-post-title{font-size:1.5rem;margin-bottom:14px}.blog-post-meta{margin-bottom:20px;padding-bottom:14px}.blog-post-date{font-size:.85rem}.edit-link{font-size:.8rem}.blog-post-tldr{padding:14px;margin-bottom:24px;font-size:.9rem;line-height:1.6}.blog-post-content{font-size:.95rem;line-height:1.6}.blog-post-content h2{font-size:1.3rem;margin-top:28px;margin-bottom:14px}.blog-post-content h3{font-size:1.15rem;margin-top:24px;margin-bottom:10px}.blog-post-content p{margin-bottom:14px}.blog-post-content ul{margin:14px 0;padding-left:20px}.blog-post-content ul li{margin-bottom:8px}.blog-post-content img{margin:20px 0;border-radius:6px}.blog-post-content pre{padding:12px;margin:14px 0;font-size:.85rem;border-radius:6px}.blog-post-content code{font-size:.85em;padding:2px 4px}}.projects{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:100px 20px 60px;position:relative;overflow:hidden}.projects:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 30% 20%,rgba(93,155,155,.08) 0%,transparent 50%),radial-gradient(circle at 70% 80%,rgba(122,184,184,.08) 0%,transparent 50%);animation:bgPulse 15s ease-in-out infinite;pointer-events:none}.projects-container{max-width:1100px;width:100%;margin:0 auto;position:relative;z-index:1}.pinned-section,.other-projects-section{display:flex;flex-direction:column;gap:20px}.pinned-section{margin-bottom:0}.other-projects-section{margin-top:50px}.section-header h2{font-size:.85rem;font-weight:700;color:#9ca3af;text-transform:uppercase;letter-spacing:.1em;margin:0;padding:0 4px}.projects-grid{display:flex;flex-direction:column;gap:30px;animation:fadeInUp .8s ease-out .2s both;max-width:100%}.project-card{background:#11182799;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(93,155,155,.2);border-radius:16px;padding:32px;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:visible;display:flex;flex-direction:row;gap:40px;align-items:flex-start;width:100%}.project-card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#5d9b9b0d,#7ab8b80d);opacity:0;transition:opacity .4s ease;pointer-events:none}.project-card:hover{border-color:#5d9b9b66;box-shadow:0 4px 16px #5d9b9b14,0 0 0 1px #5d9b9b26}.project-card:hover:before{opacity:1}.featured-project{border-color:#5d9b9b40;box-shadow:0 2px 12px #5d9b9b0f}.project-badge{position:absolute;top:20px;right:20px;background:linear-gradient(135deg,#7ab8b8,#9ba8c8,#7b8aab);color:#fff;padding:8px 18px;border-radius:20px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 4px 12px #7b8aab66,inset 0 1px #fff3;z-index:10;animation:badgePulse 3s ease-in-out infinite}@keyframes badgePulse{0%,to{box-shadow:0 4px 12px #7b8aab66,inset 0 1px #fff3}50%{box-shadow:0 4px 16px #7b8aab99,inset 0 1px #ffffff4d}}.pin-indicator{position:absolute;top:-16px;left:-16px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#7ab8b8,#9ba8c8);border-radius:50%;color:#fff;z-index:100;box-shadow:0 2px 8px #7ab8b84d;animation:pinPulse 3s ease-in-out infinite;transform:rotate(-15deg)}.pin-indicator svg{width:16px;height:16px}@keyframes pinPulse{0%,to{box-shadow:0 2px 8px #7ab8b84d}50%{box-shadow:0 3px 12px #7ab8b866}}.project-left{flex-shrink:0;display:flex;flex-direction:column;align-items:flex-start;gap:24px;width:200px}.project-header{display:flex;flex-direction:column;align-items:flex-start;gap:12px;text-align:left;width:100%}.project-icon{width:100px;height:100px;flex-shrink:0;border-radius:16px;background:linear-gradient(135deg,#5d9b9b1a,#9ba8c81a);border:1px solid rgba(122,184,184,.2);padding:8px;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.project-card:hover .project-icon{border-color:#7ab8b840;box-shadow:0 2px 8px #5d9b9b1f}.project-icon img{width:100%;height:100%;object-fit:contain;border-radius:10px;user-select:none;-webkit-user-select:none;-webkit-user-drag:none;pointer-events:none}.project-icon svg{width:100%;height:100%;filter:drop-shadow(0 4px 12px rgba(93,155,155,.3))}.project-icon.placeholder-icon svg{filter:drop-shadow(0 2px 8px rgba(93,155,155,.2))}.project-name{font-size:1.5rem;font-weight:700;color:#f3f4f6;margin:0;word-break:break-word}.project-content{flex:1;display:flex;flex-direction:column;gap:24px;min-width:0;max-width:100%;padding-top:50px;padding-bottom:0}.project-description{font-size:1.05rem;line-height:1.8;color:#d1d5db;margin:0;padding-bottom:18px;border-bottom:2px solid transparent;background-image:linear-gradient(90deg,#7ab8b880,#9ba8c84d,#7ab8b880);background-size:100% 2px;background-repeat:no-repeat;background-position:bottom}.project-features{margin:0}.project-features h3{font-size:1.05rem;font-weight:700;color:#f3f4f6;margin-bottom:16px;display:flex;align-items:center;gap:8px;letter-spacing:-.01em}.project-features ul{list-style:none;display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.project-features li{display:flex;align-items:flex-start;gap:12px;padding:14px;background:#5d9b9b08;border-radius:10px;border:1px solid rgba(93,155,155,.15);transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.project-features li:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#7ab8b81a,#9ba8c81a);opacity:0;transition:opacity .3s ease}.project-features li:hover{background:#5d9b9b14;border-color:#7ab8b840;transform:translateY(-2px);box-shadow:0 2px 8px #5d9b9b0f}.project-features li:hover:before{opacity:1}.project-features li:hover .feature-icon{background:linear-gradient(135deg,#7ab8b840,#9ba8c840);border-color:#7ab8b866;transform:scale(1.05)}.feature-icon{font-size:1.3rem;flex-shrink:0;line-height:1;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#7ab8b826,#9ba8c826);border-radius:8px;border:1px solid rgba(122,184,184,.2);transition:all .3s ease}.project-features li div{flex:1;min-width:0;position:relative;z-index:1}.project-features li strong{color:#f3f4f6;font-size:.95rem;display:block;margin-bottom:4px;font-weight:600}.project-features li p{color:#9ca3af;font-size:.85rem;line-height:1.5;margin:0}.project-tech{margin:0;width:100%}.project-tech h3{font-size:.8rem;font-weight:600;color:#9ca3af;margin-bottom:12px;text-align:left;text-transform:uppercase;letter-spacing:.05em}.tech-stack{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-start}.tech-tag{padding:8px 16px;background:transparent;border:1px solid rgba(122,184,184,.4);border-radius:6px;color:#9ba8c8;font-size:.875rem;font-weight:500;transition:all .3s ease;white-space:nowrap;letter-spacing:.01em}.tech-tag:hover{background:linear-gradient(135deg,#5d9b9b1a,#9ba8c81a);border-color:#9ba8c880}.project-links{position:absolute;top:20px;right:20px;opacity:0;transform:translateY(-10px);transition:all .3s ease;z-index:10}.project-card:hover .project-links{opacity:1;transform:translateY(0)}.project-link{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border-radius:8px;font-weight:500;font-size:.95rem;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid transparent;position:relative;overflow:hidden}.project-link:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:0;height:2px;background:linear-gradient(90deg,#5d9b9b,#7ab8b8,#9ba8c8);transition:width .4s cubic-bezier(.4,0,.2,1)}.project-link:hover:after{width:100%}.project-link.primary{background:transparent;color:#9ba8c8;border-color:#7ab8b866}.project-link.primary:hover{background:linear-gradient(135deg,#5d9b9b1a,#9ba8c81a);border-color:#9ba8c899}.project-link.secondary{background:transparent;color:#9ba8c8;border-color:#7ab8b866}.project-link.secondary:hover{background:linear-gradient(135deg,#5d9b9b1a,#9ba8c81a);border-color:#9ba8c899}.project-link svg{transition:transform .3s ease}.project-link:hover svg{transform:translate(4px)}@media (max-width: 1024px){.projects-grid{grid-template-columns:1fr}}@media (max-width: 1200px){.project-features ul{grid-template-columns:1fr}.project-left{width:150px}.project-icon{width:80px;height:80px}}@media (max-width: 768px){.projects{padding:90px 15px 40px}.projects-container{padding:0 10px}.pinned-section,.other-projects-section{gap:20px}.other-projects-section{margin-top:40px}.project-card{padding:24px 18px 80px;flex-direction:column;gap:20px}.pin-indicator{top:-12px;left:-12px;width:28px;height:28px}.pin-indicator svg{width:14px;height:14px}.project-left{width:100%;flex-direction:row;justify-content:flex-start;gap:16px}.project-header{flex-direction:row;text-align:left;align-items:center;gap:12px}.project-icon{width:60px;height:60px}.project-name{font-size:1.25rem}.project-tech{width:100%}.project-tech h3{font-size:.75rem;margin-bottom:10px}.tech-stack{gap:8px}.tech-tag{font-size:.8rem;padding:6px 12px}.project-content{padding-top:0;gap:20px}.project-description{font-size:.95rem;line-height:1.7}.project-features h3{font-size:1rem;margin-bottom:12px}.project-features ul{grid-template-columns:1fr;gap:8px}.project-features li{padding:12px;gap:10px}.feature-icon{width:32px;height:32px;font-size:1.2rem}.project-features li strong{font-size:.9rem}.project-features li p{font-size:.8rem}.project-links{bottom:18px;right:18px;opacity:1;transform:translateY(0)}.project-link{padding:10px;font-size:.9rem;gap:0;min-width:40px;justify-content:center}.project-link span{display:none}.project-link svg{width:20px;height:20px;margin:0}}@media (max-width: 480px){.projects{padding:80px 12px 30px}.projects-container{padding:0 8px}.section-header h2{font-size:.75rem}.project-card{padding:20px 15px 70px;gap:18px}.pin-indicator{width:24px;height:24px;top:-10px;left:-10px}.pin-indicator svg{width:12px;height:12px}.project-left{flex-direction:column;gap:12px}.project-header{flex-direction:row;gap:10px}.project-icon{width:50px;height:50px}.project-name{font-size:1.1rem}.tech-tag{font-size:.75rem;padding:5px 10px}.project-description{font-size:.9rem}.project-features h3{font-size:.95rem}.project-features li{padding:10px;flex-direction:column;align-items:flex-start;gap:8px}.feature-icon{width:28px;height:28px;font-size:1.1rem}.project-links{bottom:15px;right:15px}.project-link{padding:8px;font-size:.85rem;gap:0;min-width:36px;justify-content:center}.project-link span{display:none}.project-link svg{width:18px;height:18px;margin:0}}.contact{min-height:100vh;padding:100px 20px 60px;position:relative;overflow:hidden}.contact:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 30%,rgba(93,155,155,.08) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgba(155,168,200,.08) 0%,transparent 50%);animation:bgPulse 15s ease-in-out infinite;pointer-events:none}.contact-container{max-width:1100px;width:100%;margin:0 auto;position:relative;z-index:1;box-sizing:border-box}.contact-layout{display:flex;gap:50px;align-items:flex-start;animation:fadeInUp .8s ease-out .1s both;width:100%;box-sizing:border-box}.form-section,.cards-section{display:flex;flex-direction:column;gap:20px}.form-section{flex:1;min-width:0}.cards-section{flex:0 0 auto;min-width:340px}.contact-form{background:#1e293b66;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(122,184,184,.15);border-radius:16px;padding:40px 44px 44px;width:100%;box-sizing:border-box}.form-emailing-section{margin-bottom:32px}.form-emailing-section label{font-size:.95rem;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.05em;display:block;margin-bottom:10px}.email-input-wrapper{position:relative;display:flex;align-items:center}.form-emailing-section input{width:100%;padding:16px 54px 16px 18px;background:#1e293b99;border:1px solid rgba(122,184,184,.2);border-radius:10px;color:#7ab8b8;font-size:1.05rem;font-family:Courier New,Courier,monospace;font-weight:500;cursor:not-allowed;box-sizing:border-box;overflow:hidden;text-overflow:ellipsis}.email-copy-btn{position:absolute;right:10px;width:40px;height:40px;background:transparent;border:1px solid rgba(122,184,184,.3);border-radius:8px;color:#7ab8b8;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;flex-shrink:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.email-copy-btn svg{width:20px;height:20px}.email-copy-btn:hover{background:#7ab8b81a;border-color:#7ab8b880}.error-message{margin-top:8px;font-size:.875rem;color:#ef4444;font-weight:500}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}.form-group{display:flex;flex-direction:column;gap:10px}.form-group label{font-size:.95rem;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.05em}.form-group input,.form-group textarea{padding:16px 18px;background:#1e293b99;border:1px solid rgba(122,184,184,.2);border-radius:10px;color:#f3f4f6;font-size:1.05rem;font-family:inherit;transition:all .3s ease;outline:none;width:100%;box-sizing:border-box}.form-group input::placeholder,.form-group textarea::placeholder{color:#6b7280}.form-group input:focus,.form-group textarea:focus{border-color:#7ab8b880;background:#1e293bcc;box-shadow:0 0 0 3px #7ab8b81a}.form-group textarea{resize:vertical;min-height:183px;line-height:1.6}.form-submit-btn{width:100%;padding:18px 28px;background:linear-gradient(135deg,#7ab8b8,#9ba8c8);border:none;border-radius:10px;color:#fff;font-size:1.1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:12px;transition:all .3s ease;margin-top:28px;box-sizing:border-box;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.form-submit-btn svg{width:22px;height:22px}.form-submit-btn:hover:not(:disabled){box-shadow:0 6px 24px #7ab8b84d;transform:translateY(-2px)}.form-submit-btn:disabled{cursor:not-allowed;opacity:.8}.contact-cards-sidebar,.contacts-list{display:flex;flex-direction:column;gap:20px}.contact-card{background:#1e293b99;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(122,184,184,.15);border-radius:14px;padding:24px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;display:flex;flex-direction:column;gap:16px}.contact-card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#7ab8b808,#9ba8c808);opacity:0;transition:opacity .3s ease}.contact-card:hover{border-color:#7ab8b84d;box-shadow:0 4px 16px #5d9b9b1f}.contact-card:hover:before{opacity:1}.contact-card-inner{display:flex;flex-direction:row;gap:20px;align-items:center;position:relative;z-index:1}.contact-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;transition:all .3s ease;border:1px solid rgba(255,255,255,.05)}.contact-icon svg{width:28px;height:28px}.contact-card:hover .contact-icon{transform:scale(1.05);box-shadow:0 4px 16px #0003}.contact-info{display:flex;flex-direction:column;gap:8px}.contact-platform{font-size:1.2rem;font-weight:700;color:#f3f4f6;margin:0}.contact-handle{font-size:1.05rem;color:#7ab8b8;font-family:Courier New,Courier,monospace;font-weight:500;margin:0}a.contact-handle{text-decoration:none;position:relative;transition:all .2s ease}a.contact-handle:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:2px;background:linear-gradient(90deg,#7ab8b8,#9ba8c8);transition:width .3s ease}a.contact-handle:hover{color:#9ba8c8}a.contact-handle:hover:after{width:100%}@keyframes fadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.contact{padding:90px 15px 40px}.contact-container{padding:0 10px}.contact-layout{flex-direction:column;gap:35px}.form-section,.cards-section{width:100%;max-width:100%;flex:none;min-width:0}.section-header{font-size:.8rem}.contact-form{padding:28px 24px;width:100%;box-sizing:border-box}.form-emailing-section{margin-bottom:28px}.form-emailing-section label{font-size:.9rem}.form-emailing-section input{font-size:.95rem;padding:14px 48px 14px 16px;overflow:hidden;text-overflow:ellipsis}.email-copy-btn{width:36px;height:36px;right:8px;flex-shrink:0}.email-copy-btn svg{width:18px;height:18px}.form-row{grid-template-columns:1fr;gap:20px;margin-bottom:20px}.form-group label{font-size:.9rem}.form-group input,.form-group textarea{padding:14px 16px;font-size:1rem;width:100%;box-sizing:border-box}.form-group textarea{min-height:150px;resize:vertical}.form-submit-btn{padding:16px 24px;font-size:1rem;margin-top:24px}.form-submit-btn svg{width:20px;height:20px}.contact-cards-sidebar{width:100%}.contacts-list{display:flex;flex-direction:column;gap:16px;width:100%}.contact-card{padding:20px;width:100%;box-sizing:border-box}.contact-card-inner{gap:16px}.contact-icon{width:50px;height:50px;flex-shrink:0}.contact-icon svg{width:24px;height:24px}.contact-info{min-width:0;flex:1}.contact-platform{font-size:1.1rem;word-break:break-word}.contact-handle{font-size:1rem;word-break:break-all;overflow-wrap:break-word}}@media (max-width: 480px){.contact{padding:80px 12px 30px}.contact-container{padding:0 8px}.contact-layout{gap:30px}.section-header{font-size:.75rem}.contact-form{padding:20px 18px;width:100%;box-sizing:border-box}.form-emailing-section{margin-bottom:24px}.form-emailing-section label{font-size:.85rem}.form-emailing-section input{font-size:.9rem;padding:12px 44px 12px 14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.email-copy-btn{width:32px;height:32px;right:6px;flex-shrink:0}.email-copy-btn svg{width:16px;height:16px}.form-row{gap:18px;margin-bottom:18px}.form-group label{font-size:.85rem}.form-group input,.form-group textarea{padding:12px 14px;font-size:.95rem;width:100%;box-sizing:border-box}.form-group textarea{min-height:130px;resize:vertical}.form-submit-btn{padding:14px 20px;font-size:.95rem;margin-top:20px}.form-submit-btn svg{width:18px;height:18px}.contacts-list{display:flex;flex-direction:column;gap:14px}.contact-card{padding:18px;width:100%}.contact-card-inner{gap:14px;align-items:center}.contact-icon{width:48px;height:48px;flex-shrink:0}.contact-icon svg{width:22px;height:22px}.contact-info{min-width:0;flex:1;overflow:hidden}.contact-platform{font-size:1rem;word-break:break-word}.contact-handle{font-size:.95rem;word-break:break-all;overflow-wrap:break-word;line-height:1.4}}.privacy{min-height:100vh;padding:80px 20px 40px;position:relative;overflow:hidden}.privacy:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 30%,rgba(93,155,155,.08) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgba(155,168,200,.08) 0%,transparent 50%);animation:bgPulse 15s ease-in-out infinite;pointer-events:none}@keyframes bgPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.privacy-container{max-width:1100px;width:100%;margin:0 auto;position:relative;z-index:1;display:flex;flex-direction:column;align-items:center}@media (min-width: 769px){.privacy-container{position:relative}.privacy-container:before,.privacy-container:after{content:"";position:fixed;top:calc(60px + (100vh - 60px)/2);transform:translateY(-50%);height:65vh;min-height:600px;max-height:65vh;width:1px;background:#ffffff14;z-index:-1}.privacy-container:before{left:calc((100vw - 1100px)/2)}.privacy-container:after{right:calc((100vw - 1100px)/2)}}.privacy-content-wrapper{display:flex;flex-direction:column;gap:20px;width:100%;max-width:900px;animation:fadeInUp .8s ease-out .1s both}.section-header{font-size:.85rem;font-weight:700;color:#9ca3af;text-transform:uppercase;letter-spacing:.1em;margin:0;padding:0 4px}.privacy-header{text-align:center;margin-bottom:60px;animation:fadeInUp .8s ease-out .1s both}.privacy-icon-wrapper{width:80px;height:80px;margin:0 auto 24px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#7ab8b826,#9ba8c826);border:1px solid rgba(122,184,184,.3);border-radius:20px;color:#7ab8b8;transition:all .3s ease}.privacy-icon-wrapper svg{width:40px;height:40px}.privacy-icon-wrapper:hover{transform:translateY(-4px);box-shadow:0 8px 24px #7ab8b833;border-color:#7ab8b880}.privacy-title{font-size:3rem;font-weight:700;color:#f3f4f6;margin:0 0 12px;background:linear-gradient(135deg,#7ab8b8,#9ba8c8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.privacy-subtitle{font-size:1.15rem;color:#9ca3af;margin:0;font-weight:400}.privacy-content{display:flex;flex-direction:column;gap:16px;animation:fadeInUp .8s ease-out .2s both;max-width:900px;width:100%;margin-top:0}.privacy-section{background:#1e293b66;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(122,184,184,.15);border-radius:16px;padding:24px 32px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.privacy-section:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#7ab8b808,#9ba8c808);opacity:0;transition:opacity .3s ease;pointer-events:none}.privacy-section:hover{border-color:#7ab8b84d;transform:translateY(-2px);box-shadow:0 8px 24px #5d9b9b1f}.privacy-section:hover:before{opacity:1}.privacy-section-header{display:flex;align-items:center;gap:16px;margin-bottom:10px}.privacy-section-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#7ab8b81a,#9ba8c81a);border:1px solid rgba(122,184,184,.2);border-radius:12px;color:#7ab8b8;flex-shrink:0;transition:all .3s ease}.privacy-section:hover .privacy-section-icon{background:linear-gradient(135deg,#7ab8b833,#9ba8c833);border-color:#7ab8b866;transform:scale(1.05)}.privacy-section-icon svg{width:24px;height:24px}.privacy-section-title{font-size:1.5rem;font-weight:600;color:#f3f4f6;margin:0;letter-spacing:-.01em}.privacy-section-text{color:#d1d5db;font-size:1.05rem;line-height:1.6;margin:0;padding-left:64px}.privacy-footer{margin-top:8px;background:linear-gradient(135deg,#7ab8b81a,#9ba8c81a);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(122,184,184,.2);border-radius:16px;padding:32px 40px;animation:fadeInUp .8s ease-out .3s both}.privacy-footer-content{display:flex;align-items:flex-start;gap:24px}.privacy-footer-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#7ab8b826,#9ba8c826);border:1px solid rgba(122,184,184,.3);border-radius:14px;color:#7ab8b8;flex-shrink:0}.privacy-footer-icon svg{width:28px;height:28px}.privacy-footer-text{flex:1}.privacy-footer-title{font-size:1.35rem;font-weight:600;color:#f3f4f6;margin:0 0 8px;letter-spacing:-.01em}.privacy-footer-description{color:#d1d5db;font-size:1.05rem;line-height:1.7;margin:0}.privacy-footer-link{color:#7ab8b8;text-decoration:none;font-weight:500;position:relative;transition:color .3s ease}.privacy-footer-link:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:2px;background:linear-gradient(90deg,#7ab8b8,#9ba8c8);transition:width .3s ease}.privacy-footer-link:hover{color:#9ba8c8}.privacy-footer-link:hover:after{width:100%}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.privacy{padding:90px 0 40px}.privacy-container{padding:0;margin:0;max-width:100%;width:100%}.privacy-container:before,.privacy-container:after{display:none}.privacy-content-wrapper{padding:0 20px}.privacy-header{margin-bottom:40px}.privacy-icon-wrapper{width:64px;height:64px;margin-bottom:20px}.privacy-icon-wrapper svg{width:32px;height:32px}.privacy-title{font-size:2.25rem}.privacy-subtitle{font-size:1rem}.privacy-content{gap:14px}.privacy-section{padding:20px 24px}.privacy-section-header{gap:12px;margin-bottom:8px}.privacy-section-icon{width:40px;height:40px}.privacy-section-icon svg{width:20px;height:20px}.privacy-section-title{font-size:1.25rem}.privacy-section-text{font-size:1rem;padding-left:0;margin-top:4px;line-height:1.6}.privacy-footer{padding:24px}.privacy-footer-content{flex-direction:column;gap:20px}.privacy-footer-icon{width:48px;height:48px}.privacy-footer-icon svg{width:24px;height:24px}.privacy-footer-title{font-size:1.2rem}.privacy-footer-description{font-size:1rem;line-height:1.6}}@media (max-width: 480px){.privacy{padding:80px 0 30px}.privacy-container{padding:0;margin:0;width:100%}.privacy-container:before,.privacy-container:after{display:none}.privacy-content-wrapper{padding:0 15px}.privacy-header{margin-bottom:30px}.privacy-icon-wrapper{width:56px;height:56px;margin-bottom:16px}.privacy-icon-wrapper svg{width:28px;height:28px}.privacy-title{font-size:1.875rem}.privacy-subtitle{font-size:.95rem}.privacy-content{gap:12px}.privacy-section{padding:18px 20px}.privacy-section-header{flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:6px}.privacy-section-icon{width:36px;height:36px}.privacy-section-icon svg{width:18px;height:18px}.privacy-section-title{font-size:1.1rem}.privacy-section-text{font-size:.95rem;line-height:1.6}.privacy-footer{padding:20px}.privacy-footer-content{gap:16px}.privacy-footer-icon{width:44px;height:44px}.privacy-footer-icon svg{width:22px;height:22px}.privacy-footer-title{font-size:1.1rem}.privacy-footer-description{font-size:.95rem;line-height:1.6}}.snake-container{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;z-index:9999}.snake-svg{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none}.snake-svg path{transition:opacity .3s ease-out}.snake-svg path.snake-fade-out{opacity:0;transition:opacity 1s ease-out}.snake-line{animation:lineFadeIn .3s ease-out,lineFadeOut 3s ease-out 0s forwards}@keyframes lineFadeIn{0%{opacity:0;stroke-width:0}to{opacity:1;stroke-width:4}}@keyframes lineFadeOut{0%{opacity:1}70%{opacity:1}to{opacity:0}}.click-indicator{animation:clickPulse .8s ease-in-out infinite}.click-indicator-outer{animation:clickPulseOuter .8s ease-in-out infinite}@keyframes clickPulse{0%,to{opacity:.8}50%{opacity:1}}@keyframes clickPulseOuter{0%,to{opacity:.2}50%{opacity:.4}}.tail-particle{animation:particleFadeIn .2s ease-out}@keyframes particleFadeIn{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.drawing-head{animation:headGlow .6s ease-in-out infinite}@keyframes headGlow{0%,to{opacity:.8}50%{opacity:1}}body.snake-drawing-active{user-select:none!important;-webkit-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important}body.snake-drawing-active *{user-select:none!important;-webkit-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important;cursor:default!important}body.snake-drawing-active *{pointer-events:none!important}body.snake-drawing-active .navbar,body.snake-drawing-active .navbar *,body.snake-drawing-active .home-container,body.snake-drawing-active .home-container *,body.snake-drawing-active .projects-container,body.snake-drawing-active .projects-container *,body.snake-drawing-active .contact-container,body.snake-drawing-active .contact-container *,body.snake-drawing-active .words-container,body.snake-drawing-active .words-container *,body.snake-drawing-active .blog-post-container,body.snake-drawing-active .blog-post-container *{pointer-events:auto!important;cursor:auto!important}.home-container,.projects-container,.contact-container,.words-container,.blog-post-container,.privacy-container{pointer-events:auto;position:relative;z-index:10}img,svg,.profile-image,.project-icon,.contact-icon-wrapper,.logo,.image-placeholder{user-select:none!important;-webkit-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important;-webkit-user-drag:none;-webkit-touch-callout:none}img::selection,svg::selection{background:transparent}img::-moz-selection,svg::-moz-selection{background:transparent}p,h1,h2,h3,h4,h5,h6,span,li,a,code{user-select:text;-webkit-user-select:text}:root{--accent-teal: #5D9B9B;--accent-teal-light: #7AB8B8;--accent-teal-dark: #4A8080;--accent-purple: #9BA8C8;--accent-purple-dark: #7B8AAB;--accent-purple-light: #B5C0D8;--tan-primary: #D4A574;--tan-secondary: #C17A4D}::selection{background:#5d9b9b4d;color:inherit}::-moz-selection{background:#5d9b9b4d;color:inherit}.navbar{position:fixed;top:0;left:0;right:0;height:60px;background:linear-gradient(135deg,#374151d9,#2d3748e6,#1e293bf2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.1);box-shadow:0 4px 16px #0000004d,inset 0 1px #ffffff1a;z-index:1000;animation:navSlideDown .5s ease-out}@keyframes navSlideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.navbar-container{max-width:1100px;width:100%;height:100%;margin:0 auto;padding:0;display:flex;align-items:center;justify-content:space-between;gap:20px}.nav-links,.navbar-right{display:flex;align-items:center;gap:20px}.effects-toggles{display:flex;align-items:center;gap:8px}.effect-toggle{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#11182799;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(93,155,155,.2);border-radius:8px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);padding:0;color:#ffffff80}.effect-toggle svg{width:18px;height:18px;transition:all .3s ease}.effect-toggle:hover{border-color:#5d9b9b66;background:#5d9b9b1a;color:#7ab8b8e6;transform:translateY(-2px)}.effect-toggle.active{border-color:#7ab8b899;background:#5d9b9b26;color:#7ab8b8;box-shadow:0 0 12px #7ab8b84d}.effect-toggle.active svg{filter:drop-shadow(0 0 4px rgba(122,184,184,.6))}.nav-link{color:#d1d5db;text-decoration:none;font-size:1rem;font-weight:500;padding:8px 16px;border-radius:8px;transition:all .3s ease;position:relative}.nav-link:after{content:"";position:absolute;bottom:6px;left:16px;right:16px;width:auto;height:2px;background:linear-gradient(90deg,#5d9b9b,#7ab8b8,#9ba8c8);transform:scaleX(0);transition:transform .3s ease;transform-origin:left}.nav-link:hover{color:#fff;background:linear-gradient(135deg,#5d9b9b1a,#9ba8c81a)}.nav-link:hover:after{transform:scaleX(1)}.nav-link.active{color:#fff;background:linear-gradient(135deg,#5d9b9b26,#9ba8c826)}.nav-link.active:after{transform:scaleX(1)}.container{max-width:900px;margin:0 auto;padding:100px 20px 40px}@media (max-width: 768px){.container{padding:90px 15px 30px}}@media (max-width: 480px){.container{padding:80px 12px 20px}}.page-header{margin-bottom:40px;padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.1)}.page-title{font-size:2rem;font-weight:700;margin-bottom:10px}.breadcrumb{font-size:1.1rem;color:#9ca3af}.breadcrumb a{color:#e5e7eb;font-weight:600;transition:color .2s}.breadcrumb a:hover{color:#9ba8c8}.breadcrumb span{margin:0 8px;color:#6b7280}.particles{position:fixed;top:0;left:0;width:100%;height:100%;overflow:hidden;pointer-events:none;z-index:0;opacity:1;transition:opacity .8s ease-out}.particles.fading-out{opacity:0}.particle{position:absolute;top:-10px;width:2px;height:2px;background:#93c5fd99;border-radius:50%;box-shadow:0 0 4px #93c5fdcc,0 0 8px #667eea66;animation:particleFall linear infinite}.particle:nth-child(2n){background:#a78bfa99;box-shadow:0 0 4px #a78bfacc,0 0 8px #764ba266}.particle:nth-child(3n){width:3px;height:3px}.particle:nth-child(5n){width:1px;height:1px;opacity:.7}@keyframes particleFall{0%{transform:translateY(0) translate(0);opacity:0}10%{opacity:1}90%{opacity:1}to{transform:translateY(100vh) translate(50px);opacity:0}}.stars-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1;overflow:hidden;opacity:1;transition:opacity .8s ease-out}.stars-container.fading-out{opacity:0}.falling-star{position:absolute;width:25px;height:25px;top:-50px;animation:starFall 10s linear infinite;filter:drop-shadow(0 0 8px rgba(255,215,0,.8)) drop-shadow(0 0 15px rgba(255,215,0,.6)) drop-shadow(0 0 25px rgba(255,165,0,.4))}@keyframes starFall{0%{transform:translate(0) rotate(0);opacity:0}10%{opacity:1}90%{opacity:1}to{transform:translate(100px,calc(100vh + 100px)) rotate(360deg);opacity:0}}.lightning-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:2;opacity:1;transition:opacity .8s ease-out}.lightning-container.fading-out{opacity:0}.lightning{position:absolute;width:30px;height:10%;top:45%;opacity:0;animation:lightningStrike 10s infinite;filter:drop-shadow(0 0 8px rgba(212,165,116,.8)) drop-shadow(0 0 15px rgba(193,122,77,.6)) drop-shadow(0 0 25px rgba(122,155,118,.4))}.lightning-1{left:15%;animation-delay:2s}.lightning-2{right:15%;animation-delay:5s}.lightning-3{left:25%;animation-delay:7s}.lightning-4{right:25%;animation-delay:9s}@keyframes lightningStrike{0%,to{opacity:0}45%{opacity:0}46%{opacity:.6}47%{opacity:.2}48%{opacity:.8}49%{opacity:.4}50%{opacity:1}51%{opacity:.3}52%{opacity:.9}53%{opacity:.5}54%{opacity:.7}55%{opacity:.3}56%{opacity:.8}57%{opacity:.4}58%{opacity:.6}59%{opacity:.2}60%{opacity:0}}.mobile-menu-toggle{display:none;background:transparent;border:1px solid rgba(122,184,184,.3);border-radius:8px;color:#d1d5db;cursor:pointer;padding:8px;width:40px;height:40px;align-items:center;justify-content:center;transition:all .3s ease;flex-shrink:0}.mobile-menu-toggle:hover{background:#7ab8b81a;border-color:#7ab8b880;color:#7ab8b8e6}.mobile-menu-toggle svg{width:24px;height:24px}.mobile-menu{display:none;position:absolute;top:100%;left:0;right:0;background:linear-gradient(135deg,#374151fa,#2d3748fa,#1e293bfa);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.1);box-shadow:0 8px 32px #0006;max-height:0;overflow:hidden;transition:max-height .3s ease-out,opacity .3s ease-out;opacity:0;z-index:999}.mobile-menu.open{max-height:600px;opacity:1}.mobile-menu-content{padding:20px;display:flex;flex-direction:column;gap:12px}.mobile-nav-link{color:#d1d5db;text-decoration:none;font-size:1rem;font-weight:500;padding:12px 16px;border-radius:8px;transition:all .3s ease;position:relative;display:flex;align-items:center}.mobile-nav-link:hover{color:#fff;background:linear-gradient(135deg,#5d9b9b26,#9ba8c826)}.mobile-nav-link.active{color:#fff;background:linear-gradient(135deg,#5d9b9b33,#9ba8c833)}.mobile-menu-divider{height:1px;background:#ffffff1a;margin:8px 0}.mobile-effects-section{display:flex;flex-direction:column;gap:12px}.mobile-effects-label{font-size:.75rem;font-weight:700;color:#9ca3af;text-transform:uppercase;letter-spacing:.1em;padding:0 16px}.mobile-effects-toggles{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.mobile-effect-toggle{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#11182799;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(93,155,155,.2);border-radius:8px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);color:#ffffff80;font-size:.9rem;font-weight:500}.mobile-effect-toggle svg{width:20px;height:20px;flex-shrink:0}.mobile-effect-toggle:hover{border-color:#5d9b9b66;background:#5d9b9b26;color:#7ab8b8e6}.mobile-effect-toggle.active{border-color:#7ab8b899;background:#5d9b9b33;color:#7ab8b8;box-shadow:0 0 12px #7ab8b84d}.mobile-effect-toggle.active svg{filter:drop-shadow(0 0 4px rgba(122,184,184,.6))}@media (max-width: 768px){.navbar{height:60px}.navbar-container{padding:0 15px;gap:10px;position:relative}.nav-links,.navbar-right{display:none}.mobile-menu-toggle{display:flex;margin-left:auto}.mobile-menu{display:block}}@media (max-width: 480px){.navbar{height:60px}.navbar-container{padding:0 12px}.mobile-menu-toggle{width:36px;height:36px;padding:6px}.mobile-menu-toggle svg{width:20px;height:20px}.mobile-menu-content{padding:16px;gap:10px}.mobile-nav-link{font-size:.95rem;padding:10px 14px}.mobile-effects-toggles{grid-template-columns:1fr}.mobile-effect-toggle{padding:10px 14px;font-size:.85rem}.mobile-effect-toggle svg{width:18px;height:18px}}*{margin:0;padding:0;box-sizing:border-box}html{overflow-y:scroll;scrollbar-gutter:stable}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#1e293b;color:#e5e7eb;min-height:100vh}code{font-family:Courier New,Courier,monospace;background:#ffffff1a;padding:2px 6px;border-radius:4px;font-size:.9em}a{color:#667eea;text-decoration:none;transition:all .2s;position:relative}a:hover{color:#8b9bfa}a:not(.no-underline):after{content:"";position:absolute;width:0;height:2px;bottom:-2px;left:0;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s ease}a:not(.no-underline):hover:after{width:100%}#root{min-height:100vh}
