.bg-dim{background-color:transparent;border-top:none;border-bottom:none}.global-background{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:-1;overflow:hidden;background-color:var(--bg-dark);pointer-events:none}.navbar{position:fixed;top:0;left:0;right:0;height:80px;display:flex;align-items:center;z-index:1000;transition:all .3s ease}.navbar.scrolled{background:#0a0a0acc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.05);height:70px}.nav-content{display:flex;justify-content:space-between;align-items:center;width:100%}.navbar .logo{font-family:var(--font-heading);font-weight:800;font-size:1.5rem;letter-spacing:-1px;color:#fff}.nav-links{display:flex;gap:2rem;align-items:center}.nav-links a{font-weight:500;font-size:.95rem;color:var(--text-secondary)}.nav-links a:hover{color:#fff}.btn-contact{padding:.5rem 1.25rem;background:#ffffff1a;border-radius:99px;color:#fff!important;transition:all .2s ease;border:1px solid transparent}.btn-contact:hover{background:#fff;color:#000!important}.app-container{position:relative;overflow-x:hidden;min-height:100vh}.global-background{position:absolute;top:0;left:0;width:100%;height:100%;z-index:-1;overflow:hidden;background-color:var(--bg-dark);pointer-events:none}.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;padding-top:80px;overflow:hidden}@keyframes float{0%,to{transform:translate(0)}50%{transform:translate(30px,-30px)}}@keyframes heartbeat-pulse{0%,to{transform:scale(1);opacity:.3}50%{transform:scale(1.15);opacity:.5}}@keyframes color-breath{0%,to{background-color:#1e1b4b}33%{background-color:#4c1d95}66%{background-color:#9240ae}}.blob{position:absolute;border-radius:50%;filter:blur(120px);opacity:.35;mix-blend-mode:normal;animation:float 20s infinite ease-in-out,heartbeat-pulse 8s infinite ease-in-out,color-breath 24s infinite alternate}.blob-1{width:900px;height:900px;top:-15%;right:-20%;animation-delay:0s,0s,-5s}.blob-2{width:1000px;height:1000px;top:5%;left:-25%;animation-delay:-5s,-2s,0s}.blob-3{width:800px;height:800px;top:35%;right:-25%;opacity:.25;animation-delay:-10s,-5s,-10s}.blob-4{width:900px;height:900px;bottom:0%;left:-20%;opacity:.3;animation-delay:-15s,-8s,-15s}.hero-content{display:grid;grid-template-columns:1.1fr .9fr;grid-template-areas:"text image" "actions image";align-items:center;gap:0 3rem}.hero-text{grid-area:text;text-align:left}.hero-actions-wrapper{grid-area:actions;display:flex;flex-direction:column;gap:1.5rem}.hero-image-container{grid-area:image;display:flex;justify-content:center;align-items:center;position:relative}.hero-kicker{text-transform:uppercase;letter-spacing:.2em;font-size:.7rem;color:var(--text-secondary);margin-bottom:1.5rem}.hero-title{margin-bottom:1.5rem}.hero-lead{font-size:1.25rem;color:var(--text-secondary);margin-bottom:2.5rem;max-width:90%}.hero-lead strong{color:#fff;font-weight:600}.hero-actions{display:flex;gap:1rem;justify-content:flex-start;margin-bottom:3rem}.hero-socials{display:flex;gap:1.5rem;justify-content:flex-start}.hero-image-container{display:flex;justify-content:center;align-items:center;position:relative}.hero-img-wrapper{position:relative;width:400px;height:480px;border-radius:24px;overflow:hidden;box-shadow:0 20px 40px #0000004d;background:var(--bg-card);border:1px solid rgba(255,255,255,.05);transform:rotate(3deg);transition:transform .3s ease}.hero-img-wrapper:hover{transform:rotate(0) scale(1.02)}.hero-img-wrapper img{width:100%;height:100%;object-fit:cover}.hero-image-container:before{content:"";position:absolute;width:400px;height:480px;border:2px solid var(--accent-primary);border-radius:24px;opacity:.3;transform:rotate(-3deg);z-index:-1}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;font-size:1rem;transition:all .2s;cursor:pointer}.btn-primary{background:#fff;color:#000}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 20px -5px #ffffff4d}.btn-outline{border:1px solid rgba(255,255,255,.2);color:#fff}.btn-outline:hover{border-color:#fff;background:#ffffff0d}.social-link{color:var(--text-secondary);transition:color .2s}.social-link:hover{color:var(--accent-primary)}.scroll-indicator{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);color:var(--text-secondary);animation:bounce 2s infinite}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0) translate(-50%)}40%{transform:translateY(-10px) translate(-50%)}60%{transform:translateY(-5px) translate(-50%)}}.section{padding:6rem 0}.section-title{font-size:2.5rem;margin-bottom:3rem;text-align:center}.about-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:4rem;align-items:center}.about-text p{margin-bottom:1.5rem;font-size:1.125rem;line-height:1.7;color:var(--text-secondary)}.about-stats{display:grid;grid-template-columns:1fr;padding:2rem;gap:2rem}.stat-item{display:flex;flex-direction:column;text-align:center;align-items:center}.stat-icon-wrapper{margin-bottom:1rem;padding:1rem;background:#ffffff0d;border-radius:50%;border:1px solid rgba(255,255,255,.05);display:flex;align-items:center;justify-content:center;transition:transform .3s ease}.stat-item:hover .stat-icon-wrapper{transform:scale(1.1) rotate(5deg);border-color:#fff3;background:#ffffff14}.stat-number{font-size:1.25rem;font-weight:700;color:#fff;line-height:1.2;margin-bottom:.5rem}.stat-label{font-size:.9rem;color:var(--text-secondary)}.story-content{max-width:1000px;margin:0 auto}.story-banner{padding:4rem 0;display:grid;grid-template-columns:1.5fr 1fr;gap:4rem;align-items:center;position:relative}.story-banner h2{font-size:2.5rem;margin-bottom:2rem;line-height:1.1;text-align:left;max-width:100%;background:linear-gradient(to right,#fff,#a1a1aa);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.name-gradient-simple{display:inline-block;background:var(--gradient-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;cursor:text;will-change:transform}.story-banner p{font-size:1.25rem;color:var(--text-secondary);margin-bottom:2.5rem;max-width:100%;text-align:justify;line-height:1.6}.story-image{position:relative;width:100%;border-radius:24px;overflow:hidden;box-shadow:0 20px 40px #0000004d;border:1px solid rgba(255,255,255,.1);background:#0003;display:flex;justify-content:center;align-items:center}.story-image:hover{border-color:#ffffff4d}.story-image img{width:100%;height:auto;display:block;filter:grayscale(100%) contrast(1.1);opacity:.9;transition:all .5s ease}@media(max-width:768px){.hero-kicker{display:none}.hero-content{gap:1.5rem;display:flex;flex-direction:column}.hero-lead{margin-bottom:1rem}.hero-img-wrapper{width:260px;height:320px;margin:0 auto}.hero-image-container:before{width:260px;height:320px}.story-banner{grid-template-columns:1fr;gap:3rem}.story-image{aspect-ratio:auto;height:auto;transform:rotate(0);max-width:100%;margin:0 auto}.story-image img{object-position:center;position:relative;width:100%;height:auto}}.btn-text{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;color:#fff;font-size:1rem;border-bottom:1px solid transparent;padding-bottom:2px;transition:gap .2s}.btn-text:hover{gap:.8rem;color:var(--accent-primary)}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.skill-card{padding:2rem;height:100%;transition:border-color .3s}.skill-card:hover{border-color:var(--accent-primary)}.skill-icon{margin-bottom:1.5rem;color:var(--accent-primary)}.skill-card h3{font-size:1.25rem;margin-bottom:1rem}.tools-wrapper{display:flex;flex-direction:column;gap:1.5rem}.tool-category{margin-bottom:2rem}.tool-category h3{font-size:1.25rem;margin-bottom:1rem;color:#fff;display:flex;align-items:center;gap:.5rem}.tool-grid{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.5rem}.tool-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem .85rem;border-radius:8px;background:#ffffff08;border:1px solid rgba(255,255,255,.05);font-size:.85rem;color:var(--text-secondary);transition:all .2s ease;cursor:default}.tool-badge:hover{background:#ffffff14;transform:translateY(-2px);border-color:#ffffff1a;color:#fff}.brand-box{width:24px;height:24px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.65rem;line-height:1;color:#000}.adobe-ps{background:#31a8ff;color:#001e36}.adobe-ai{background:#ff9a00;color:#300}.adobe-pr{background:#99f;color:#00005b}.adobe-id{background:#f36;color:#300}.office-xl{background:#1d6f42;color:#fff}.office-wd{background:#2b579a;color:#fff}.office-pp{background:#d24726;color:#fff}.office-pb{background:#f2c811;color:#000}.brand-tiktok{background:#000;color:#fff;text-shadow:1px 1px 0 #FF0050,-1px -1px 0 #00F2EA}.brand-capcut{background:#fff;color:#000}.brand-meta{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);color:#fff}.brand-qgis{background:#589632;color:#fff}.brand-spss{background:#002d62;color:#fff}.tech-icon{width:20px;height:20px}.timeline{max-width:800px;margin:0 auto;border-left:2px solid rgba(255,255,255,.1);padding-left:2rem}.timeline-item{position:relative;margin-bottom:3rem}.timeline-marker{position:absolute;left:-2.6rem;top:.5rem;width:1.2rem;height:1.2rem;background:var(--bg-dark);border:2px solid var(--accent-primary);border-radius:50%;box-shadow:0 0 0 4px #6366f133}.timeline-date{display:inline-block;font-size:.875rem;color:var(--accent-primary);font-weight:600;margin-bottom:.5rem}.timeline-content h3{font-size:1.5rem;margin-bottom:.25rem}.timeline-content h4{font-size:1.1rem;color:var(--text-secondary);font-weight:500;margin-bottom:1rem}@keyframes scroll{0%{transform:translate(0)}to{transform:translate(-50%)}}.projects-grid-wrapper{width:100%;padding:2rem 0;overflow:hidden}.projects-grid{display:flex;flex-wrap:nowrap;overflow-x:auto;gap:2rem;padding:0 1.5rem 2rem;-webkit-overflow-scrolling:touch;width:100%;touch-action:pan-y;scrollbar-width:none;-ms-overflow-style:none;user-select:none;-webkit-user-select:none;scroll-behavior:auto}.projects-grid::-webkit-scrollbar{display:none}.project-card{flex:0 0 auto;width:280px;display:flex;flex-direction:column;background:transparent;border:none;cursor:pointer;user-select:none;-webkit-user-select:none}.project-image-container{width:100%;height:180px;position:relative;border-radius:12px;border:1px solid rgba(255,255,255,.1);overflow:hidden;margin-bottom:1rem;background:#111}.project-image-container img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;display:block}.project-card img{-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.project-card:hover .project-image-container img{transform:scale(1.05)}.project-content h3{font-size:1.25rem;margin-bottom:.5rem;color:#fff;white-space:normal}.project-content p{font-size:.9rem;color:var(--text-secondary);line-height:1.5;white-space:normal}@media(min-width:769px){.projects-grid{padding:0 2rem 2rem}.project-card{width:400px}.project-image-container{height:260px;margin-bottom:1.5rem}.project-tags{font-size:.85rem;margin-bottom:.5rem}.project-content h3{font-size:1.5rem}.project-content p{font-size:1rem}.project-content{flex-grow:1;height:100%}}.project-image-container img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.project-card:hover .project-image-container img{transform:scale(1.03)}.project-content{padding:0 .5rem;display:flex;flex-direction:column}.project-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.project-tags{display:flex;gap:.5rem;font-size:.7rem;color:var(--accent-primary);text-transform:uppercase;letter-spacing:.1em;font-weight:700}.project-year{font-size:.75rem;color:var(--text-secondary);opacity:.7}.project-card h3{font-size:1.5rem;margin-bottom:.75rem;color:#fff;font-weight:600;letter-spacing:-.02em}.project-card p{font-size:1rem;line-height:1.6;color:var(--text-secondary);margin-bottom:1rem;flex-grow:1}.project-footer{margin-top:auto;display:flex;justify-content:center;align-items:center;width:100%}.link-text{display:inline-flex;align-items:center;gap:.35rem;font-size:.9rem;font-weight:600;color:#fff;transition:gap .2s}.project-card:hover .link-text{gap:.6rem;color:var(--accent-primary)}.contact-section{background:linear-gradient(to top,#0f0f10,transparent)}.contact-lead{font-size:1.5rem;max-width:600px;margin:0 auto 2.5rem}.btn-large{padding:1rem 2.5rem;font-size:1.125rem}.footer-socials{margin-top:3rem;display:flex;gap:2rem;justify-content:center}.footer-socials a{color:var(--text-secondary);font-size:.875rem}.footer-socials a:hover{text-decoration:underline}footer{padding:2rem 0;border-top:1px solid rgba(255,255,255,.05);text-align:center;font-size:.875rem;color:var(--text-secondary);margin-top:auto}@media(max-width:1024px){.hero-content{grid-template-columns:1fr;text-align:center;gap:4rem;padding-top:2rem}.hero-text{text-align:center;order:2;order:1}.hero-image-container{order:2}.hero-actions,.hero-socials{justify-content:center}.hero-lead{margin-left:auto;margin-right:auto}}@media(max-width:768px){.nav-links{display:none}.about-grid{grid-template-columns:1fr;gap:3rem}.hero-img-wrapper,.hero-image-container:before{width:300px;height:360px}.about-stats{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.about-stats{grid-template-columns:1fr}.hero-title{font-size:2.2rem}.hero-img-wrapper,.hero-image-container:before{width:260px;height:320px}.hero{padding-top:60px}}.logo-img{height:24px;width:auto}.lightbox{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000e6;display:flex;justify-content:center;align-items:center;z-index:9999;padding:1rem;animation:fadeIn .3s ease}.lightbox-content{position:relative;max-width:90vw;max-height:90vh;display:flex;justify-content:center;align-items:center}.lightbox-content img{max-width:100%;max-height:90vh;object-fit:contain;border-radius:8px;box-shadow:0 0 50px #00000080}.lightbox-close{position:absolute;top:-40px;right:-10px;background:none;border:none;color:#fff;cursor:pointer;padding:.5rem;transition:transform .2s}.lightbox-close:hover{transform:scale(1.1);color:var(--accent-primary)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.image-overlay-hint{position:absolute;top:0;left:0;width:100%;height:100%;background:#0006;display:flex;justify-content:center;align-items:center;opacity:0;transition:opacity .3s ease}.project-image-container:hover .image-overlay-hint{opacity:1}.mobile-scroll-hint{display:none}@media(max-width:768px){.mobile-scroll-hint{display:flex;justify-content:center;align-items:center;gap:1rem;margin-bottom:1.5rem;color:var(--text-secondary);font-size:.9rem;animation:pulse-hint 2s infinite ease-in-out}.mobile-scroll-hint svg{color:var(--accent-primary)}}@keyframes pulse-hint{0%,to{opacity:.6;transform:scale(.98)}50%{opacity:1;transform:scale(1.02)}}:root{--bg-dark: #0a0a0a;--bg-card: #171717;--bg-card-hover: #262626;--text-primary: #ededed;--text-secondary: #a1a1aa;--accent-primary: #6366f1;--accent-secondary: #a855f7;--accent-glow: rgba(99, 102, 241, .4);--gradient-text: linear-gradient(to right, #ffffff, #c7d2fe);--gradient-bg: linear-gradient(135deg, #0f172a 0%, #1e1b4b 100%);--font-body: "Inter", sans-serif;--font-heading: "Outfit", sans-serif}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background-color:var(--bg-dark);color:var(--text-primary);font-family:var(--font-body);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:700;color:#fff;line-height:1.2}h1{font-size:clamp(2.5rem,5vw,4rem);letter-spacing:-.02em}h2{font-size:2rem;margin-bottom:2rem}p{color:var(--text-secondary);font-size:1.05rem;text-align:justify}a{color:inherit;text-decoration:none;transition:color .2s ease}ul{list-style:none}.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}.gradient-text{background:var(--gradient-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.glass-panel{background:#ffffff08;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.05);border-radius:12px}
