/*! tailwindcss v4.1.11 | MIT License | https://tailwindcss.com */@layer properties{@supports ((-webkit-hyphens:none) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-duration:initial;--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000}}}.fixed{position:fixed}.z-50{z-index:50}.container{width:100%}.mx-auto{margin-inline:auto}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.w-full{width:100%}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.rounded-full{border-radius:3.40282e38px}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.text-center{text-align:center}.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,ease);transition-duration:var(--tw-duration,0s)}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.duration-200{--tw-duration:.2s;transition-duration:.2s}@media (hover:hover){.hover\:scale-105:hover{--tw-scale-x:105%;--tw-scale-y:105%;--tw-scale-z:105%;scale:var(--tw-scale-x)var(--tw-scale-y)}}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(2px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}html{scroll-behavior:smooth}html.lenis-active{scroll-behavior:auto}.gradient-bg{background:linear-gradient(135deg,#0f172a,#1e293b)}.text-gradient-cyan{-webkit-text-fill-color:transparent;background:linear-gradient(90deg,#0ff,#4ddcff);-webkit-background-clip:text;background-clip:text}.text-gradient-blue{-webkit-text-fill-color:transparent;background:linear-gradient(90deg,#2986ff,#1259c2);-webkit-background-clip:text;background-clip:text}.skill-badge{transition:all .2s}.skill-badge:hover{transform:scale(1.05)}.section-title{margin-bottom:2.5rem;display:inline-block;position:relative}.section-title:after{content:"";background:linear-gradient(90deg,#3b82f6,#0ea5e9);border-radius:2px;width:60%;height:4px;position:absolute;bottom:-10px;left:0}.terminal{background-color:#0f172a;border-radius:8px;max-width:100%;margin:0 auto;padding:1.5rem;position:relative;box-shadow:0 10px 15px -3px #00000080}@media (max-width:768px){.terminal{margin:0 1rem;padding:1rem}}@media (max-width:480px){.terminal{margin:0;padding:.75rem;font-size:.875rem}}.terminal-header{gap:8px;display:flex;position:absolute;top:15px;right:15px}.terminal-dot{cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:12px;min-width:12px;height:12px;min-height:12px;font-size:0;transition:all .2s;display:flex}.terminal-dot:hover{width:16px;min-width:16px;height:16px;min-height:16px;font-size:8px}.dot-red:hover:before{content:"×"}.dot-yellow:hover:before{content:"−"}.dot-green:hover:before{content:"+"}.dot-red{background-color:#ef4444}.dot-yellow{background-color:#f59e0b}.dot-green{background-color:#10b981}.terminal-content{margin-top:2.5rem;font-family:JetBrains Mono,monospace;font-size:.875rem;line-height:1.5;overflow-x:auto}@media (max-width:768px){.terminal-content{margin-top:2rem;font-size:.75rem}}@media (max-width:480px){.terminal-content{margin-top:1.5rem;font-size:.7rem}.terminal-content .path{word-break:break-word}}.command{color:#0ea5e9}.path{color:#10b981}.cursor{background-color:#f8fafc;width:8px;height:18px;margin-left:4px;animation:1s infinite blink;display:inline-block}@keyframes blink{0%{opacity:1}50%{opacity:0}to{opacity:1}}.hero{background:linear-gradient(135deg,#0f172a,#1e293b,#334155);align-items:center;min-height:100vh;padding:2rem 0;display:flex;position:relative;overflow:hidden}.hero:before,.hero:after{content:"";filter:blur(80px);opacity:.15;border-radius:50%;position:absolute}.hero:before{background:radial-gradient(circle,#3b82f6,#0000 70%);width:600px;height:600px;animation:60s ease-in-out infinite orb-drift-1}.hero:after{background:radial-gradient(circle,#0ea5e9,#0000 70%);width:500px;height:500px;animation:75s ease-in-out infinite orb-drift-2}@keyframes orb-drift-1{0%{top:-10%;left:-5%}25%{top:20%;left:50%}50%{top:60%;left:80%}75%{top:30%;left:20%}to{top:-10%;left:-5%}}@keyframes orb-drift-2{0%{top:80%;left:70%}25%{top:40%;left:10%}50%{top:-5%;left:40%}75%{top:50%;left:75%}to{top:80%;left:70%}}.hero-content{z-index:1;grid-template-columns:1fr 1fr;align-items:center;gap:4rem;max-width:1200px;margin:0 auto;padding:0 1rem;display:grid;position:relative}@media (max-width:1024px){.hero-content{gap:3rem;padding:0 1.5rem}}@media (max-width:768px){.hero{min-height:90vh;padding:1rem 0}.hero-content{text-align:center;grid-template-columns:1fr;gap:2rem;padding:0 1rem}.hero-terminal{order:-1}.terminal{max-width:100%;margin:0}}.hero-text{color:#fff}.hero-title{margin-bottom:1rem;font-size:clamp(2rem,5vw,4rem);font-weight:700;line-height:1.1}.highlight{-webkit-text-fill-color:transparent;background:linear-gradient(45deg,#3b82f6,#0ea5e9);-webkit-background-clip:text;background-clip:text}.hero-subtitle{color:#0ea5e9;margin-bottom:1.5rem;font-size:clamp(1.125rem,3vw,1.5rem);font-weight:500}.hero-description{color:#cbd5e1;margin-bottom:2rem;font-size:clamp(1rem,2.5vw,1.125rem);line-height:1.7}.hero-buttons{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}@media (max-width:768px){.hero-buttons{justify-content:center}}@media (max-width:480px){.hero-buttons{flex-direction:column;width:100%}.hero-buttons .btn{width:100%;max-width:280px;margin:0 auto}}.btn{cursor:pointer;border:2px solid #0000;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-weight:500;text-decoration:none;transition:all .2s;display:inline-flex}.btn-primary{color:#fff;background:linear-gradient(45deg,#3b82f6,#0ea5e9)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 25px #3b82f64d}.btn-secondary{color:#0ea5e9;background:0 0;border-color:#0ea5e9}.btn-secondary:hover{color:#fff;background:#0ea5e9;transform:translateY(-2px)}.btn-outline{color:#cbd5e1;background:0 0;border-color:#94a3b84d}.btn-outline:hover{color:#0ea5e9;background:#0ea5e91a;border-color:#0ea5e9}.btn-full{width:100%}.hero-terminal{justify-content:center;align-items:center;display:flex}.fade-in{animation:.8s forwards fadeInUp}.fade-in-delay{opacity:0;animation:.8s .3s forwards fadeInUp}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}section{padding:5rem 0}@media (max-width:768px){section{padding:3rem 0}}@media (max-width:480px){section{padding:2rem 0}}.container{max-width:1200px;margin:0 auto;padding:0 2rem}@media (max-width:768px){.container{padding:0 1rem}}.section-title{text-align:center;color:#fff;margin-bottom:1rem;font-size:2.5rem;font-weight:700}@media (max-width:768px){.section-title{font-size:2rem}}@media (max-width:480px){.section-title{font-size:1.75rem}}.section-subtitle{color:#64748b;text-align:center;margin-bottom:3rem;font-size:1.125rem}@media (max-width:768px){.section-subtitle{margin-bottom:2rem;font-size:1rem}}.projects{background:linear-gradient(135deg,#0f172a,#1e293b)}.carousel-scene{perspective:1200px;margin-bottom:1.5rem;padding:2rem 4rem;position:relative;overflow:hidden}.carousel-track{justify-content:center;align-items:center;height:520px;display:flex;position:relative}.carousel-card{pointer-events:none;will-change:transform,opacity,filter;width:100%;max-width:900px;position:absolute}.carousel-card-active{pointer-events:auto}.carousel-card-tilt{transition:transform .15s ease-out}.carousel-card-inner{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0f172acc;border:1px solid #94a3b826;border-radius:16px;grid-template-columns:1fr 1fr;height:480px;display:grid;position:relative;overflow:hidden;box-shadow:0 25px 50px #0006,inset 0 0 0 1px #94a3b81a}.carousel-card-active .carousel-card-inner{border-color:#0ea5e933}.project-image{position:relative;overflow:hidden}.project-image img{-o-object-fit:cover;object-fit:cover;-o-object-position:center;object-position:center;width:100%;height:100%;transition:transform .5s}.carousel-card-active:hover .project-image img{transform:scale(1.05)}.project-info{z-index:2;flex-direction:column;justify-content:center;gap:1rem;padding:2rem;display:flex;position:relative}.project-title{color:#f1f5f9;font-size:1.5rem;font-weight:700}.project-description{color:#94a3b8;font-size:.95rem;line-height:1.6}.project-tech{flex-wrap:wrap;gap:.5rem;display:flex}.tech-tag{color:#7dd3fc;background:#0ea5e91a;border:1px solid #0ea5e933;border-radius:20px;padding:.25rem .75rem;font-size:.8rem;font-weight:500;transition:all .2s}.tech-tag:hover{background:#0ea5e933;border-color:#0ea5e966}.project-links{flex-wrap:wrap;gap:.75rem;display:flex}.carousel-nav{z-index:20;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#94a3b8;cursor:pointer;background:#0f172acc;border:1px solid #94a3b833;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;transition:all .2s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.carousel-nav:hover{color:#0ea5e9;background:#0ea5e91a;border-color:#0ea5e9;transform:translateY(-50%)scale(1.1)}.carousel-nav-prev{left:0}.carousel-nav-next{right:0}.carousel-indicators{justify-content:center;gap:.75rem;margin-bottom:1rem;display:flex}.carousel-dot{cursor:pointer;background:0 0;border:none;width:32px;height:3px;padding:8px 0;position:relative}.carousel-dot-fill{background:#94a3b84d;border-radius:2px;width:100%;height:3px;transition:all .3s;display:block}.carousel-dot.active .carousel-dot-fill{background:#0ea5e9;box-shadow:0 0 8px #0ea5e966}.carousel-dot:hover .carousel-dot-fill{background:#94a3b880}.carousel-dot.active:hover .carousel-dot-fill{background:#38bdf8}.carousel-counter{text-align:center;color:#475569;letter-spacing:.1em;font-family:JetBrains Mono,monospace;font-size:.85rem}.carousel-counter-current{color:#0ea5e9;font-weight:600}.carousel-counter-sep{margin:0 .25rem}@media (max-width:1024px){.carousel-card-inner{height:450px}.carousel-card{max-width:95%}}@media (max-width:768px){.carousel-scene{perspective:none;padding:1rem 0}.carousel-track{height:auto}.carousel-card{max-width:100%;height:0;position:relative;overflow:hidden;filter:none!important;opacity:0!important;visibility:hidden!important;transition:none!important;transform:none!important}.carousel-card-active{height:auto;overflow:visible;opacity:1!important;visibility:visible!important}.carousel-card-inner{grid-template-columns:1fr;height:auto}.project-image{height:220px}.project-info{padding:1.5rem}.carousel-nav{display:none}.carousel-indicators{gap:.5rem}.carousel-dot{width:24px;padding:12px 0}}.skills{background:linear-gradient(135deg,#0f172a,#1e293b)}.skills-categories{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;display:grid}@media (max-width:768px){.skills-categories{grid-template-columns:1fr;gap:1.25rem}}.skill-category{background:#1e293b80;border:1px solid #94a3b81a;border-radius:12px;padding:1.5rem;transition:border-color .3s}.skill-category:hover{border-color:#0ea5e94d}.skill-category h3{color:#0ea5e9;text-transform:uppercase;letter-spacing:.05em;margin-bottom:1rem;font-size:1rem;font-weight:600}.skill-tags{flex-wrap:wrap;gap:.5rem;display:flex}.skill-tag{color:#cbd5e1;background:#0ea5e91a;border:1px solid #0ea5e933;border-radius:6px;padding:.375rem .75rem;font-size:.85rem;transition:all .2s}.skill-tag:hover{color:#f1f5f9;background:#0ea5e933;border-color:#0ea5e966}.contact{color:#fff;background:#0f172a}.contact .section-title,.contact .section-subtitle{color:#fff}.contact .section-subtitle{color:#cbd5e1}.contact-content{grid-template-columns:1fr 1fr;align-items:start;gap:4rem;display:grid}@media (max-width:768px){.contact-content{grid-template-columns:1fr;gap:2rem}.contact-info{order:2}.contact-form{order:1}}.contact-info h3{-webkit-text-fill-color:transparent;background:linear-gradient(45deg,#3b82f6,#0ea5e9);-webkit-background-clip:text;background-clip:text;margin-bottom:2rem;font-size:1.5rem;font-weight:700}@media (max-width:480px){.contact-info h3{margin-bottom:1.5rem;font-size:1.25rem}}.contact-item{color:#cbd5e1;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}@media (max-width:480px){.contact-item{gap:.75rem;margin-bottom:1rem;font-size:.95rem}}.contact-item svg{color:#0ea5e9;flex-shrink:0}@media (max-width:480px){.contact-item svg{width:20px;height:20px}}.contact-item a{color:#cbd5e1;text-decoration:none;transition:color .2s}.contact-item a:hover{color:#0ea5e9}.btn-unstyled{color:inherit;cursor:pointer;font:inherit;background:0 0;border:none;padding:0;text-decoration:underline}.contact-form{background:#1e293b;border:1px solid #334155;border-radius:12px;padding:2rem}@media (max-width:768px){.contact-form{padding:1.5rem}}@media (max-width:480px){.contact-form{padding:1rem}}.form-group{margin-bottom:1.5rem}@media (max-width:480px){.form-group{margin-bottom:1rem}}.form-group label{color:#f1f5f9;margin-bottom:.5rem;font-weight:500;display:block}@media (max-width:480px){.form-group label{font-size:.9rem}}.form-group input,.form-group textarea{color:#fff;background:#0f172a;border:2px solid #334155;border-radius:8px;width:100%;padding:.75rem;font-size:1rem;transition:border-color .2s}@media (max-width:480px){.form-group input,.form-group textarea{padding:.625rem;font-size:.9rem}}.form-group input:focus,.form-group textarea:focus{border-color:#0ea5e9;outline:none}.form-group input::-moz-placeholder,.form-group textarea::-moz-placeholder{color:#64748b}.form-group input::placeholder,.form-group textarea::placeholder{color:#64748b}@media (max-width:480px){.text-responsive{font-size:.875rem;line-height:1.4}.container{padding-left:1rem;padding-right:1rem}button,.btn{min-width:44px;min-height:44px}.terminal-dot{width:12px!important;min-width:12px!important;height:12px!important;min-height:12px!important}.terminal-dot:hover{width:16px!important;min-width:16px!important;height:16px!important;min-height:16px!important}section{padding:2rem 0}.section-title{margin-bottom:.75rem;font-size:1.75rem}.section-subtitle{margin-bottom:1.5rem;font-size:.95rem}.hero-buttons{gap:.75rem}.hero-buttons .btn{padding:.875rem 1.25rem;font-size:.95rem}.form-group input,.form-group textarea{font-size:16px}}@media (max-width:768px) and (orientation:landscape){.hero{min-height:100vh;padding:1rem 0}.hero-content{gap:2rem}.terminal{max-width:400px}section{padding:2.5rem 0}}@media (max-width:320px){.container{padding-left:.75rem;padding-right:.75rem}.hero-title{font-size:1.75rem}.hero-subtitle{font-size:1rem}.hero-description{font-size:.875rem}.btn{padding:.5rem 1rem;font-size:.825rem}.terminal{padding:.5rem;font-size:.75rem}}@media (min-width:768px) and (max-width:1024px){.hero-content{gap:3rem;padding:0 2rem}.container{padding:0 1.5rem}.section-title{font-size:2.25rem}}@media (hover:none) and (pointer:coarse){.btn,button{min-width:48px;min-height:48px}.terminal-dot{width:12px!important;min-width:12px!important;height:12px!important;min-height:12px!important}.project-links .btn{padding:.875rem 1.25rem}.contact-item a{padding:.25rem 0;display:inline-block}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-duration{syntax:"*";inherits:false}@property --tw-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}
