/*! tailwindcss v4.1.8 | MIT License | https://tailwindcss.com */@layer theme{:host,:root{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,::backdrop,:after,:before{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}:host,html{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}menu,ol,ul{list-style:none}audio,canvas,embed,iframe,img,object,svg,video{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,optgroup,select,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit,::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.grid{display:grid}.hidden{display:none}.resize{resize:both}.bg-\[\'\#6366f1\'\]{background-color:"#6366f1"}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,visibility,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}:root{--primary:#6366f1;--primary-dark:#4f46e5;--secondary:#0ea5e9;--accent:#8b5cf6;--background:#fff;--foreground:#1f2937;--muted:#6b7280;--border:#e5e7eb;--card-bg:#fff;--gradient:linear-gradient(135deg,var(--primary)0%,var(--secondary)100%);--shadow-sm:0 1px 2px 0 #0000000d;--shadow:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a}*{box-sizing:border-box;margin:0;padding:0;font-family:Anuphan,sans-serif}body{background-color:var(--background);color:var(--foreground);font-family:Inter,Noto Sans Thai,sans-serif;overflow-x:hidden}.portfolio-container{min-height:100vh;position:relative}.cursor{border:2px solid var(--primary);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:none;z-index:9999;background:#6366f133;border-radius:50%;width:32px;height:32px;transition:all .3s;position:fixed;transform:translate(-50%,-50%)}.cursor.hover{background:#6366f166;width:48px;height:48px}.cursor-dot{background:var(--primary);pointer-events:none;z-index:9999;border-radius:50%;width:8px;height:8px;transition:all .2s;position:fixed;transform:translate(-50%,-50%)}.canvas-bg{z-index:-1;width:100%;height:100%;position:fixed;top:0;left:0}.container{max-width:1200px;margin:0 auto;padding:0 2rem}.navbar{z-index:1000;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow);background:#fffc;border-bottom:1px solid #ffffff1a;padding:1.5rem 0;position:fixed;top:0;left:0;right:0}.nav-container{justify-content:space-between;max-width:1200px;margin:0 auto;padding:0 2rem}.nav-brand,.nav-container{align-items:center;display:flex}.nav-brand{gap:.5rem;font-size:1.25rem;font-weight:700}.brand-icon{background:var(--gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.5rem}.nav-menu{gap:2rem;display:flex}.nav-link{color:var(--text-secondary);cursor:pointer;text-transform:capitalize;background:0 0;border:none;padding:.5rem 0;font-size:.9rem;font-weight:500;transition:all .3s;position:relative}.nav-link:after{content:"";background:var(--gradient);border-radius:3px;width:0;height:3px;transition:width .3s;position:absolute;bottom:0;left:0}.nav-link.active:after,.nav-link:hover:after{width:100%}.nav-link.active,.nav-link:hover{color:var(--text)}.menu-toggle{cursor:pointer;background:0 0;border:none;flex-direction:column;gap:4px;padding:.5rem;display:none}.menu-toggle span{background:var(--text);border-radius:1px;width:25px;height:2px;transition:all .3s}.hero{min-height:100vh;position:relative;overflow:hidden}.hero:before{content:"";background:radial-gradient(circle at top right,var(--primary)0,transparent 70%);opacity:.1;pointer-events:none;position:absolute;inset:0}.hero-content{grid-template-columns:1fr 1.5fr;align-items:center;gap:4rem;max-width:1200px;margin:0 auto;display:grid}.hero-image{transform-style:preserve-3d;border-radius:30px;position:relative;overflow:hidden}.hero-image img{transition:transform .3s;transform:translateZ(0)}.hero-image:hover img{transform:scale(1.05)translateZ(20px)}.profile-image{object-fit:cover;width:100%;height:100%;transition:transform .3s}.hero-image:hover .profile-image{transform:scale(1.05)}.hero-image-overlay{pointer-events:none;background:linear-gradient(45deg,#667eea33,#764ba233);position:absolute;inset:0}.hero-text{text-align:left}.hero-badge{color:var(--primary);background:#4f46e51a;border:1px solid #4f46e533;border-radius:50px;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;display:inline-flex}.hero-badge span{align-items:center;gap:.5rem;display:flex}.hero-title{margin-bottom:1.5rem;font-size:clamp(2.5rem,8vw,5rem);font-weight:900;line-height:1.1}.title-line{opacity:0;animation:fadeInUp 1s forwards;display:block}.title-line:first-child{animation-delay:.2s}.title-line:nth-child(2){animation-delay:.4s}.title-line:nth-child(3){animation-delay:.6s}.gradient-text{background:var(--gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-subtitle{color:var(--text-secondary);opacity:0;max-width:600px;margin:0 auto 3rem;font-size:1.25rem;animation:fadeInUp 1s .8s forwards}.hero-buttons{opacity:0;flex-wrap:wrap;justify-content:center;gap:1rem;animation:fadeInUp 1s 1s forwards;display:flex}.btn-primary,.btn-secondary{border-radius:12px;padding:12px 24px;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.btn-primary{background:linear-gradient(135deg,#4f46e5,#7c3aed) 0 0/200%;background:var(--primary);color:#fff;border:none}.btn-primary:before{content:"";background:linear-gradient(135deg,#fff3,#0000);width:100%;height:100%;transition:transform .3s;position:absolute;top:0;left:0;transform:translate(-100%)}.btn-primary:hover:before{transform:translate(0)}.btn-secondary{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:var(--glass-border);box-shadow:var(--glass-shadow);color:var(--primary);background:#6366f11a;transition:all .4s cubic-bezier(.175,.885,.32,1.275)}.btn-secondary:hover{background:#6366f133;transform:translateY(-3px)scale(1.05)}.hero-scroll{color:var(--text-secondary);flex-direction:column;align-items:center;gap:1rem;font-size:.9rem;display:flex;position:absolute;bottom:2rem;left:50%;transform:translate(-50%)}.scroll-indicator{background:var(--gradient);border-radius:1px;width:2px;height:30px;animation:scroll-bounce 2s infinite}section{padding:6rem 0}.section-header{text-align:center;margin-bottom:4rem}.section-badge{color:var(--primary);background:#667eea1a;border:1px solid #667eea33;border-radius:50px;padding:.5rem 1rem;font-size:.9rem;font-weight:500}.section-title{background:var(--gradient);-webkit-text-fill-color:transparent;filter:drop-shadow(0 2px 4px #6366f14d);background-size:200%;-webkit-background-clip:text;background-clip:text;margin-top:1rem;font-size:clamp(2rem,5vw,3rem);font-weight:800;animation:gradient-shift 5s infinite}.about-content{grid-template-columns:1fr 1fr;align-items:start;gap:40px;display:grid}.about-lead{color:var(--primary);border-left:4px solid var(--primary);margin-bottom:30px;padding-left:20px;font-size:1.5rem;font-weight:600;line-height:1.4;position:relative}.about-text p{margin-bottom:20px;line-height:1.8}.about-stats{grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px;display:grid}.stat{background:var(--card-bg);text-align:center;border:1px solid var(--border);box-shadow:var(--shadow);border-radius:16px;padding:20px;transition:all .3s}.stat:hover{box-shadow:var(--shadow-lg);transform:translateY(-5px)}.stat-number{color:var(--primary);margin-bottom:5px;font-size:2.5rem;font-weight:700;display:block}.stat-label{color:var(--muted);font-size:.9rem}.skills-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:2rem;margin-top:3rem;display:grid}.skill-card{background:var(--card-bg);border:1px solid var(--border);transform-style:preserve-3d;perspective:1000px;opacity:0;border-radius:16px;padding:24px;transition:background .3s cubic-bezier(.4,0,.2,1),border-color .3s cubic-bezier(.4,0,.2,1);transform:translateY(50px)}.skill-icon{background:var(--gradient);-webkit-text-fill-color:transparent;filter:drop-shadow(0 2px 4px #6366f14d);-webkit-background-clip:text;background-clip:text;margin-bottom:1rem;font-size:2.5rem}.skill-name{margin-bottom:.5rem;font-size:1.2rem;font-weight:600}.skill-bar{background:#667eea1a;border-radius:5px;width:100%;margin-bottom:.5rem;overflow:hidden}.skill-progress{background:linear-gradient(90deg,var(--primary)var(--progress),var(--border)var(--progress));border-radius:4px;height:8px;position:relative;overflow:hidden}.skill-progress:before{content:"";background:linear-gradient(90deg,#fff3,#0000 50%,#fff3);width:100%;height:100%;animation:shimmer 2s linear infinite;position:absolute;top:0;left:0}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skill-level{color:var(--text-secondary);margin-top:.5rem;font-family:Fira Code,monospace;font-size:.9rem}.portfolio{background:linear-gradient(#fffc,#fffffff2);padding:8rem 0;position:relative;overflow:hidden}.portfolio:before{content:"";opacity:.05;pointer-events:none;background:url(/images/grid-pattern.svg);position:absolute;inset:0}.portfolio-filters{flex-wrap:wrap;justify-content:center;gap:15px;margin-bottom:40px;display:flex}.filter-btn{border:1px solid var(--border);background:var(--card-bg);color:var(--muted);cursor:pointer;border-radius:30px;padding:10px 20px;font-weight:500;transition:all .3s}.filter-btn.active,.filter-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary);transform:translateY(-2px)}.portfolio-grid{perspective:1000px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:30px;display:grid}.project-card{background:var(--card-bg);border:1px solid var(--border);border-radius:20px;transition:all .3s}.project-card,.project-image{position:relative;overflow:hidden}.project-image{aspect-ratio:16/9}.project-image img{object-fit:cover;width:100%;height:100%;transition:transform .3s}.project-overlay{color:#fff;background:linear-gradient(#0000,#000000e6);padding:30px;transition:transform .3s;position:absolute;bottom:0;left:0;right:0;transform:translateY(100%)}.project-card:hover .project-overlay{transform:translateY(0)}.project-card:hover .project-image img{transform:scale(1.1)}.project-meta{align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.project-year{color:var(--primary);background:#6366f11a;border:1px solid #6366f133;border-radius:50px;font-weight:600}.project-type,.project-year{padding:.3rem 1rem;font-size:.9rem}.project-type{color:var(--text);background:#ffffff1a;border:1px solid #fff3;border-radius:50px;font-weight:500}.project-title{color:var(--text);-webkit-text-fill-color:transparent;background:linear-gradient(90deg,#fff,#ffffffb3);-webkit-background-clip:text;background-clip:text;margin-bottom:1rem;font-size:1.8rem;font-weight:700;line-height:1.3}.project-description{color:var(--text-secondary);opacity:.9;margin-bottom:1.5rem;font-size:1rem;line-height:1.6}.project-stack{flex-wrap:wrap;gap:.75rem;display:flex}.stack-item{color:var(--text);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #ffffff1a;border-radius:50px;padding:.4rem 1rem;font-size:.85rem;font-weight:500;transition:all .3s}.stack-item:hover{background:var(--primary);border-color:var(--primary);transform:translateY(-2px)}.project-actions{flex-direction:column;gap:1rem;display:flex}.action-btn.primary{background:var(--gradient);color:#fff;cursor:pointer;border:none;border-radius:50px;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.75rem 1.5rem;font-size:.9rem;font-weight:600;transition:all .3s;display:flex}.action-btn.primary:hover{transform:translateY(-2px);box-shadow:0 10px 20px #6366f133}.action-links{justify-content:center;gap:1rem;display:flex}.action-link{color:var(--text-secondary);align-items:center;gap:.3rem;font-size:.9rem;text-decoration:none;transition:all .3s;display:flex}.action-link:hover{color:var(--text);transform:translateY(-2px)}.link-icon{font-size:1.2rem}.modal-overlay{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);opacity:0;background:#111827f2;animation:fadeIn .3s forwards}.modal-content{width:100%;max-width:1000px;border-radius:24px;animation:slideUp .5s cubic-bezier(.4,0,.2,1) forwards;transform:translateY(20px)}.modal-image-container{width:100%;height:500px;position:relative;overflow:hidden}.modal-image{object-fit:cover;width:100%;height:100%;transition:transform .5s}.modal-details{background:linear-gradient(#1e293bf2,#1e293bfa);padding:2.5rem}.modal-meta{gap:1rem;margin-bottom:1.5rem;display:flex}.modal-type,.modal-year{color:var(--text);background:#ffffff1a;border:1px solid #fff3;border-radius:50px;padding:.4rem 1.2rem;font-size:.9rem;font-weight:500}.modal-title{background:var(--gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:1rem;font-size:2.5rem;font-weight:700;line-height:1.3}.modal-description{color:var(--text-secondary);margin-bottom:2rem;font-size:1.1rem;line-height:1.7}.modal-stack{flex-wrap:wrap;gap:1rem;margin-bottom:2.5rem;display:flex}.modal-stack-item{color:var(--text);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #ffffff1a;border-radius:50px;padding:.5rem 1.2rem;font-size:.9rem;font-weight:500;transition:all .3s}.modal-stack-item:hover{background:var(--primary);border-color:var(--primary);transform:translateY(-2px)}.modal-actions{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;display:grid}.modal-btn{cursor:pointer;border:none;border-radius:50px;justify-content:center;align-items:center;gap:.5rem;padding:1rem 2rem;font-size:1rem;font-weight:600;text-decoration:none;transition:all .3s;display:flex}.modal-btn.source{color:var(--primary);background:#6366f11a;border:1px solid #6366f133}.modal-btn.demo{color:#fff;background:linear-gradient(135deg,#4f46e5,#7c3aed)}.modal-btn.download{color:#fff;background:linear-gradient(135deg,#34d399,#3b82f6)}.modal-btn.play{color:#fff;background:linear-gradient(135deg,#f43f5e,#ec4899)}.modal-btn:hover{transform:translateY(-3px);box-shadow:0 10px 20px #0003}.modal-close{color:var(--text);z-index:10;background:#ffffff1a;border:1px solid #fff3;top:1.5rem;right:1.5rem}.modal-close:hover{background:var(--primary);border-color:var(--primary)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.modal-image-container{height:300px}.modal-details{padding:1.5rem}.modal-title{font-size:1.8rem}.modal-description{font-size:1rem}.modal-actions{grid-template-columns:1fr}.modal-btn{width:100%}.portfolio{padding:4rem 0}.portfolio-grid{grid-template-columns:1fr}.project-card.featured{grid-column:span 1}.project-image{height:250px}.filter-btn{padding:.5rem 1rem;font-size:.8rem}.project-actions{flex-direction:column}.action-btn.primary{width:100%}.action-links{flex-wrap:wrap;justify-content:flex-start}.modal-content{width:95vw}}@media (max-width:480px){.portfolio-filters{flex-direction:column;align-items:stretch}.filter-group,.view-options{justify-content:center}.filter-btn{padding:.4rem .8rem;font-size:.75rem}.project-image{height:200px}.project-title{font-size:1.2rem}.project-description{font-size:.9rem}}.portfolio-grid.list-view{grid-template-columns:1fr;transition:all .3s}.portfolio-grid.list-view .project-card{grid-template-columns:300px 1fr;gap:2rem;transition:all .3s;display:grid}.portfolio-grid.list-view .project-image{height:100%;transition:all .3s}.portfolio-grid.list-view .project-overlay{opacity:1;-webkit-backdrop-filter:none;backdrop-filter:none;background:0 0;padding:1.5rem;transition:all .3s;position:relative}.portfolio-grid.list-view .overlay-content{transition:all .3s;transform:none}.fade-enter{opacity:0;transform:translateY(20px)}.fade-enter-active{transition:opacity .3s,transform .3s}.fade-enter-active,.fade-exit{opacity:1;transform:translateY(0)}.fade-exit-active{opacity:0;transition:opacity .3s,transform .3s;transform:translateY(20px)}.contact-content{grid-template-columns:1fr 1fr;align-items:start;gap:4rem;display:grid}.contact-info{color:var(--text-secondary);font-size:1.1rem}.contact-info h3{color:var(--text);margin-bottom:1rem;font-size:1.3rem;font-weight:600}.contact-methods{flex-direction:column;gap:1rem;margin-top:1.5rem;display:flex}.contact-method{color:var(--text-secondary);align-items:center;gap:.5rem;text-decoration:none;transition:all .3s;display:flex}.contact-method:hover{color:var(--text)}.method-icon{color:var(--primary);font-size:1.5rem}.social-links{gap:16px;display:flex}.social-link{color:var(--primary);background:#6366f11a;border-radius:12px;padding:12px 24px;font-weight:500;transition:all .3s}.social-link:hover{background:var(--primary);color:#fff}.contact-form{gap:1.5rem}.contact-form,.form-group{flex-direction:column;display:flex}.form-group label{color:var(--text-secondary);margin-bottom:.5rem;font-size:.9rem}.form-group input,.form-group textarea{border:2px solid var(--border);background:#fffc;border-radius:12px;padding:12px;transition:all .3s}.form-group input:focus,.form-group textarea:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 4px #6366f11a}.contact-form button{background:var(--gradient);color:#fff;cursor:pointer;border-radius:50px;align-items:center;gap:.5rem;padding:1rem 2rem;font-weight:600;transition:all .3s;display:flex}.contact-form button:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.footer{background:var(--surface);text-align:center;border-top:1px solid var(--border);padding:2rem 0}.footer-content{flex-direction:column;gap:1rem}.footer-brand,.footer-content{align-items:center;display:flex}.footer-brand{gap:.5rem;font-size:1.25rem;font-weight:700}.footer-brand .brand-icon{background:var(--gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.5rem}.footer-text{color:var(--text-secondary);font-size:.9rem}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scroll-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@media (max-width:768px){.navbar{background:#0a0a0af2;border-bottom:1px solid #ffffff1a;padding:1rem 0}.nav-menu{background:#0a0a0afa}.nav-link{margin:1rem 0;transition:all .3s}.hero{min-height:auto;padding:6rem 1.5rem}.hero-content{text-align:center;grid-template-columns:1fr;gap:2rem;padding:2rem 1rem}.hero-image{aspect-ratio:1;max-width:250px;margin:0 auto}.hero-title{font-size:clamp(2rem,6vw,3rem)}.hero-subtitle{margin-bottom:2rem;font-size:1rem}.hero-buttons{flex-direction:column;gap:1rem}.btn-primary,.btn-secondary{justify-content:center;width:100%}.about-content{grid-template-columns:1fr;gap:2rem}.about-stats{grid-template-columns:repeat(2,1fr);gap:1.5rem}.contact-content,.portfolio-grid,.skills-grid,.testimonials-grid{grid-template-columns:1fr}.contact-content{gap:3rem}.nav-menu,.social-links{justify-content:center}.nav-menu{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000;background:#030712f2;flex-direction:column;align-items:center;gap:2rem;width:100%;height:100vh;transition:all .5s cubic-bezier(.77,0,.175,1);display:flex;position:fixed;top:0;right:-100%}.nav-menu.active{right:0}.nav-link{opacity:0;font-size:1.5rem;transform:translateY(20px)}.nav-menu.active .nav-link{opacity:1;transition:all .3s;transform:translateY(0)}.nav-menu.active .nav-link:first-child{transition-delay:.1s}.nav-menu.active .nav-link:nth-child(2){transition-delay:.2s}.nav-menu.active .nav-link:nth-child(3){transition-delay:.3s}.nav-menu.active .nav-link:nth-child(4){transition-delay:.4s}.nav-menu.active .nav-link:nth-child(5){transition-delay:.5s}.project-card,.service-card,.skill-card,.testimonial-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#111827b3;border:1px solid #ffffff1a;border-radius:15px;margin:0 1rem;padding:1.5rem;transition:all .3s;transform:translateY(0)}.project-card:active,.service-card:active,.testimonial-card:active{transform:scale(.98)}.form-group input,.form-group textarea{border-radius:12px;padding:1rem;font-size:16px}.contact-form button{justify-content:center;width:100%;padding:1rem;font-size:1rem}.footer{padding:2rem 1rem}.footer-content{text-align:center}}@media (max-width:480px){.container{padding:0 1rem}.hero{padding:4rem 1rem}.hero-image{max-width:200px}.hero-title{font-size:clamp(1.8rem,5vw,2.5rem)}.about-stats{grid-template-columns:1fr}.stat{padding:1rem}.section-title{font-size:clamp(1.8rem,4vw,2.5rem)}.cursor-inner,.cursor-outer,.cursor-trail{display:none}.btn-primary:active,.btn-secondary:active,.nav-link:active,.project-card:active{transition:transform .2s;transform:scale(.95)}.fade-up{transform:translateY(20px)}.fade-up.visible{transform:translateY(0)}::-webkit-scrollbar{width:4px}.about-text,.hero-subtitle,.project-description,.service-description{font-size:.9rem;line-height:1.6}section{padding:4rem 0}.section-header{margin-bottom:2rem}.project-card,.service-card,.skill-card,.testimonial-card{margin:.5rem 0}}@media (min-width:769px) and (max-width:1024px){.hero-content{text-align:center;grid-template-columns:1fr;gap:3rem}.hero-image{max-width:300px;margin:0 auto}.about-content{grid-template-columns:1fr;gap:3rem}.portfolio-grid,.services-grid,.skills-grid{grid-template-columns:repeat(2,1fr)}.contact-content{grid-template-columns:1fr;gap:4rem}}@media (max-height:480px) and (orientation:landscape){.hero{min-height:auto;padding:4rem 1rem}.hero-content{grid-template-columns:1fr 1fr;gap:2rem}.hero-image{max-width:200px}.nav-menu{padding:2rem}.nav-link{margin:.5rem 0;font-size:1.2rem}}@media (prefers-color-scheme:dark){:root{--primary:#818cf8;--secondary:#a78bfa;--accent:#f472b6}}@media (prefers-contrast:high){:root{--primary:#06f;--secondary:#93f;--accent:#f39;--text:#fff;--text-secondary:#ccc}}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--background)}::-webkit-scrollbar-thumb{background:var(--primary);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--primary-dark)}html{scroll-behavior:smooth;scroll-padding-top:80px}.loading{background:linear-gradient(90deg,var(--surface)25%,var(--border)50%,var(--surface)75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.scale-in{opacity:0;transition:all .6s cubic-bezier(.77,0,.175,1);transform:scale(.9)}.scale-in.visible{opacity:1;transform:scale(1)}@media (max-width:480px){.hero-title{font-size:2rem}.hero-subtitle{font-size:1rem}.btn-primary,.btn-secondary{padding:.75rem 1.5rem;font-size:.9rem}.portfolio-grid{grid-template-columns:1fr}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes gradient-shift{0%{background-position:0}50%{background-position:100%}to{background-position:0}}.gradient-bg{background:var(--gradient);background-size:200% 200%;animation:gradient-shift 15s infinite}.cursor-outer{border:2px solid #6366f180;width:40px;height:40px;transition:width .2s ease-out,height .2s ease-out,border-color .2s ease-out,transform .1s ease-out}.cursor-inner,.cursor-outer{pointer-events:none;z-index:9999;mix-blend-mode:difference;will-change:transform;border-radius:50%;position:fixed;transform:translate(-50%,-50%)}.cursor-inner{background:var(--primary);width:8px;height:8px;transition:width .1s ease-out,height .1s ease-out,opacity .2s ease-out,transform .1s ease-out}.cursor-hover{border-color:var(--accent)!important;background:0 0!important;width:60px!important;height:60px!important;transition:all .2s ease-out!important}.cursor-inner.cursor-hover{opacity:0;width:0;height:0}.cursor-click{animation:cursorClick .3s ease-out forwards;border-color:var(--accent)!important;width:24px!important;height:24px!important;transition:all .1s ease-out!important}@keyframes cursorClick{0%{opacity:1;transform:translate(-50%,-50%)scale(1)}50%{opacity:.8;transform:translate(-50%,-50%)scale(.8)}to{opacity:1;transform:translate(-50%,-50%)scale(1)}}.cursor-ripple{pointer-events:none;z-index:9998;border:2px solid var(--accent);opacity:1;will-change:transform,opacity;border-radius:50%;width:20px;height:20px;animation:ripple .5s linear forwards;position:fixed}@keyframes ripple{0%{opacity:1;transform:translate(-50%,-50%)scale(1)}to{opacity:0;transform:translate(-50%,-50%)scale(4)}}.cursor-trail{background:var(--primary);pointer-events:none;z-index:9997;opacity:.3;will-change:transform,opacity;border-radius:50%;width:4px;height:4px;transition:opacity .2s;position:fixed}@media (hover:none) and (pointer:coarse){.cursor-inner,.cursor-outer,.cursor-ripple,.cursor-trail{display:none!important}}.btn-primary,.btn-secondary,.nav-link,.project-card,.social-link{cursor:none}.timeline{max-width:1000px;margin:0 auto;padding:2rem 0;position:relative;overflow:hidden}.timeline-line{transform-origin:top;z-index:1;background:#3b82f6;width:2px;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.timeline-item{opacity:1;z-index:2;align-items:center;min-height:120px;margin-bottom:3rem;display:flex;position:relative}.timeline-content:after,.timeline-content:before,.timeline-dot:after,.timeline-dot:before{display:none!important}.timeline-item.left{flex-direction:row-reverse}.timeline-item.left .timeline-content{text-align:right;margin-right:3rem}.timeline-item.right .timeline-content{text-align:left;margin-left:3rem}.timeline-dot{z-index:10;background:#3b82f6;border:3px solid #fff;border-radius:50%;width:16px;height:16px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.timeline-content{background:#fff;border:1px solid #e5e7eb;border-radius:12px;flex:1;max-width:45%;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.timeline-date{color:#fff;background:#3b82f6;border-radius:20px;margin-bottom:.5rem;padding:.25rem .75rem;font-size:.875rem;font-weight:600;display:inline-block}.timeline-content h3{color:#1f2937;margin:.5rem 0;font-size:1.25rem;font-weight:700}.timeline-place{color:#6b7280;margin-bottom:.5rem;font-weight:600}.timeline-description{color:#4b5563;margin:0;line-height:1.6}.timeline *,.timeline :after,.timeline :before{transition:none!important;animation:none!important}@media (max-width:768px){.timeline-line{left:2rem}.timeline-item{flex-direction:row!important}.timeline-item .timeline-content{max-width:calc(100% - 4rem);text-align:left!important;margin-left:3rem!important;margin-right:1rem!important}.timeline-dot{left:2rem}}.experience-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem;margin-top:3rem;display:grid}.experience-card{background:var(--glass-gradient);-webkit-backdrop-filter:var(--glass-blur);border:var(--glass-border);box-shadow:var(--glass-shadow);border-radius:15px;padding:2rem;transition:all .3s}.experience-header{margin-bottom:1rem}.experience-header h3{margin-bottom:.5rem;font-size:1.2rem;font-weight:600}.company{color:var(--primary);margin-bottom:.3rem;font-size:1rem;display:block}.date{color:var(--text-secondary);font-size:.9rem;display:block}.experience-description{color:var(--text-secondary);font-size:.95rem;line-height:1.6}.certificates-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem;margin-top:3rem;display:grid}.certificate-card{background:var(--glass-gradient);-webkit-backdrop-filter:var(--glass-blur);border:var(--glass-border);box-shadow:var(--glass-shadow);border-radius:15px;transition:all .3s;overflow:hidden}.certificate-image{width:100%;height:200px;overflow:hidden}.certificate-image img{object-fit:cover;width:100%;height:100%;transition:transform .3s}.certificate-card:hover .certificate-image img{transform:scale(1.05)}.certificate-content{padding:1.5rem}.certificate-type{color:var(--primary);background:#6366f11a;border-radius:20px;margin-bottom:.8rem;padding:.3rem .8rem;font-size:.8rem;display:inline-block}.certificate-content h3{margin-bottom:.8rem;font-size:1.2rem;font-weight:600}.certificate-content p{color:var(--text-secondary);margin-bottom:.8rem;font-size:.95rem;line-height:1.6}.certificate-date{color:var(--text-secondary);font-size:.9rem;display:block}@media (max-width:768px){.timeline-item{text-align:left;width:100%;padding-left:60px}.timeline-item:nth-child(2n){left:0}.timeline-line{left:20px}.timeline-dot{left:11px!important;right:auto!important}.about-content{grid-template-columns:1fr}.about-stats{grid-template-columns:repeat(2,1fr)}.portfolio-grid{grid-template-columns:1fr}}.goals-section,.hobbies-section{margin-top:2rem}.goals-section h4,.hobbies-section h4{color:var(--text);margin-bottom:1rem;font-size:1.1rem;font-weight:600}.goals-list,.hobbies-list{margin:0;padding:0;list-style:none}.goals-list li,.hobbies-list li{color:var(--text-secondary);margin-bottom:.5rem;padding-left:1.5rem;font-size:.95rem;position:relative}.hobbies-list li:before{content:"🎯";position:absolute;left:0}.goals-list li:before{content:"✨";position:absolute;left:0}@media (max-width:768px){.goals-section,.hobbies-section{margin-top:1.5rem}.goals-list li,.hobbies-list li{font-size:.9rem}}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000e6;justify-content:center;align-items:center;padding:2rem;display:flex;position:fixed;inset:0}.modal-content{background:var(--glass-gradient);max-width:90vw;max-height:90vh;-webkit-backdrop-filter:var(--glass-blur);border:var(--glass-border);box-shadow:var(--glass-shadow);border-radius:15px;position:relative;overflow:hidden}.modal-image{object-fit:contain;max-width:100%;max-height:80vh}.modal-close{background:var(--gradient);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.5rem;transition:all .3s;display:flex;position:absolute;top:1rem;right:1rem}.modal-close:hover{transform:rotate(90deg)}.modal-title{color:var(--text);text-align:center;background:var(--glass-gradient);padding:1rem;font-size:1.2rem;font-weight:600}@media (max-width:768px){.project-card.featured{grid-column:span 1}.project-image{height:200px}.modal-content{width:95vw}}.btn-secondary,.filter-btn,.view-btn{background:var(--glass-gradient);-webkit-backdrop-filter:var(--glass-blur);border:var(--glass-border);box-shadow:var(--glass-shadow);transition:all .4s cubic-bezier(.175,.885,.32,1.275);position:relative;overflow:hidden}.btn-secondary:before,.filter-btn:before,.view-btn:before{content:"";background:linear-gradient(120deg,#0000,#fff3,#0000);width:100%;height:100%;transition:all .5s;position:absolute;top:0;left:-100%}.btn-primary:hover:before,.btn-secondary:hover:before,.filter-btn:hover:before,.view-btn:hover:before{left:100%}.btn-primary:hover,.btn-secondary:hover,.filter-btn:hover,.view-btn:hover{transform:translateY(-5px)scale(1.02);box-shadow:0 15px 30px #0000004d}.certificate-card,.experience-card,.project-card,.skill-card{background:var(--glass-gradient);-webkit-backdrop-filter:var(--glass-blur);border:var(--glass-border);box-shadow:var(--glass-shadow);transition:all .4s cubic-bezier(.175,.885,.32,1.275);position:relative;overflow:hidden}.certificate-card:before,.experience-card:before,.project-card:before{content:"";background:linear-gradient(120deg,#0000,#ffffff1a,#0000);width:100%;height:100%;transition:all .5s;position:absolute;top:0;left:-100%}.certificate-card:hover:before,.experience-card:hover:before,.project-card:hover:before{left:100%}.certificate-card:hover,.experience-card:hover,.project-card:hover,.skill-card:hover{border-color:#fff3;transform:translateY(-10px)scale(1.02);box-shadow:0 20px 40px #0006}@keyframes liquidFlow{0%{background-position:0}50%{background-position:100%}to{background-position:0}}.certificate-card:hover,.experience-card:hover,.project-card:hover,.skill-card:hover{background:linear-gradient(45deg,#ffffff1a,#ffffff0d,#ffffff1a) 0 0/200% 200%;animation:liquidFlow 3s infinite}@media (max-width:768px){.btn-primary,.btn-secondary,.certificate-card,.experience-card,.project-card,.skill-card{-webkit-backdrop-filter:var(--glass-blur)}}.fade-up{opacity:1;transition:all .6s cubic-bezier(.4,0,.2,1);transform:none}.fade-up.animate{opacity:0;transform:translateY(30px)}.scale-up{opacity:1;transition:all .6s cubic-bezier(.4,0,.2,1);transform:none}.scale-up.animate{opacity:0;transform:scale(.9)}.navbar{transition:all .3s}.navbar-scrolled{box-shadow:var(--shadow);background:#fffffff2}.about-text,.certificate-card,.experience-card,.hero-badge,.hero-buttons,.hero-subtitle,.project-card,.section-header,.skills-grid,.timeline-item,.title-line{opacity:1}.skill-progress{width:0;transition:width 1.5s ease-out}.project-card{transition:transform .3s,box-shadow .3s}.project-card:hover{transform:translateY(-10px);box-shadow:0 20px 40px #0000001a}.certificate-card{transition:transform .3s,box-shadow .3s}.certificate-card:hover{transform:scale(1.02);box-shadow:0 15px 30px #0000001a}.timeline-item{transition:transform .3s}.timeline-item:hover{transform:translate(10px)}.form-group input,.form-group textarea{transition:border-color .3s,box-shadow .3s}.form-group input:focus,.form-group textarea:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.btn-primary,.btn-secondary{transition:transform .2s,box-shadow .2s}.btn-primary:hover,.btn-secondary:hover{transform:translateY(-2px);box-shadow:0 5px 15px #0000001a}.social-link{transition:color .3s,transform .3s}.social-link:hover{color:#6366f1;transform:translateY(-2px)}