/*! 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}.static{position:static}.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}body{scroll-behavior:smooth}.gradient-bg{background:linear-gradient(135deg,#0f172a,#1e293b)}.project-card{border-radius:12px;transition:all .3s;position:relative;overflow:hidden}.project-card:hover{transform:translateY(-5px);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.project-card:before{content:"";z-index:10;background:linear-gradient(90deg,#3b82f6,#0ea5e9);height:4px;position:absolute;top:0;left:0;right:0}.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{content:"";background:radial-gradient(circle at 30% 20%,#3b82f61a,#0000 50%),radial-gradient(circle at 70% 80%,#0ea5e91a,#0000 50%);position:absolute;top:0;right:0;bottom:0;left:0}.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:#000;background:0 0;border-color:#475569}.btn-outline:hover{color:#0ea5e9;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)}.project-showcase{justify-content:center;align-items:center;margin-bottom:2rem;display:flex;position:relative}.project-nav{z-index:10;cursor:pointer;color:#475569;background:#fff;border:2px solid #e2e8f0;border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;transition:all .2s;display:flex;position:absolute}.project-nav:hover{color:#0ea5e9;border-color:#0ea5e9;transform:scale(1.1)}.project-nav-prev{left:-25px}.project-nav-next{right:-25px}@media (max-width:768px){.project-nav{display:none}.project-showcase{flex-direction:column;gap:1rem}}.project-card{background:#fff;border-radius:12px;grid-template-columns:1fr 1fr;width:100%;max-width:1000px;height:500px;display:grid;position:relative;overflow:hidden;box-shadow:0 10px 25px #0000001a}@media (max-width:768px){.project-card:after{content:"Swipe left/right to navigate";color:#fff;z-index:10;opacity:.7;pointer-events:none;background:#000000b3;border-radius:12px;padding:.25rem .75rem;font-size:.75rem;position:absolute;bottom:10px;left:50%;transform:translate(-50%)}}@media (max-width:1024px){.project-card{max-width:90%;height:450px}}@media (max-width:768px){.project-card{grid-template-columns:1fr;max-width:100%;height:auto;min-height:400px}.project-image{min-height:200px;max-height:250px}.project-image img{-o-object-fit:cover;object-fit:cover;height:100%}}@media (max-width:480px){.project-card{min-height:350px;margin:0 .5rem}}.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 .3s}.project-card:hover .project-image img{transform:scale(1.05)}.project-info{flex-direction:column;justify-content:space-between;padding:2rem;display:flex}@media (max-width:768px){.project-info{padding:1.5rem}}@media (max-width:480px){.project-info{padding:1rem}}.project-title{color:#1e293b;margin-bottom:1rem;font-size:1.5rem;font-weight:700}@media (max-width:480px){.project-title{font-size:1.25rem}}.project-description{color:#475569;flex-grow:1;margin-bottom:1.5rem;line-height:1.6}@media (max-width:480px){.project-description{margin-bottom:1rem;font-size:.9rem}}.project-tech{flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem;display:flex}@media (max-width:480px){.project-tech{gap:.25rem;margin-bottom:1rem}}.tech-tag{color:#475569;background:#f1f5f9;border-radius:20px;padding:.25rem .75rem;font-size:.875rem;font-weight:500}@media (max-width:480px){.tech-tag{padding:.2rem .5rem;font-size:.75rem}}.project-links{flex-wrap:wrap;gap:1rem;display:flex}@media (max-width:480px){.project-links{gap:.5rem}.project-links .btn{flex:1;min-width:0;padding:.625rem 1rem;font-size:.875rem}}.project-indicators{justify-content:center;gap:.5rem;margin-top:2rem;display:flex}@media (max-width:768px){.project-indicators{gap:.75rem;margin-top:1.5rem}}.indicator{cursor:pointer;background:#cbd5e1;border:none;border-radius:50%;width:12px;height:12px;transition:all .2s;position:relative}@media (max-width:768px){.indicator{width:16px;height:16px}}@media (max-width:480px){.indicator{width:20px;height:20px}}.indicator.active{background:#0ea5e9;transform:scale(1.2);box-shadow:0 0 0 4px #0ea5e933}@media (max-width:768px){.indicator.active{transform:scale(1.1)}}.indicator:hover{background:#94a3b8;transform:scale(1.1)}.indicator.active:hover{background:#0284c7}.skills{background:linear-gradient(135deg,#0f172a,#1e293b)}.skills-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-bottom:3rem;display:grid}@media (max-width:768px){.skills-grid{grid-template-columns:1fr;gap:1rem;margin-bottom:2rem}}@media (max-width:480px){.skills-grid{grid-template-columns:1fr;gap:.75rem}}.skill-item{background:#f8fafc;border-left:4px solid #0ea5e9;border-radius:8px;padding:1.5rem}@media (max-width:480px){.skill-item{padding:1rem}}.skill-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.skill-name{color:#1e293b;font-weight:600}@media (max-width:480px){.skill-name{font-size:.9rem}}.skill-percentage{color:#0ea5e9;font-weight:600}.skill-bar{background:#e2e8f0;border-radius:4px;width:100%;height:8px;overflow:hidden}.skill-progress{background:linear-gradient(90deg,#3b82f6,#0ea5e9);border-radius:4px;height:100%;transition:width 1s}.skills-categories{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;display:grid}@media (max-width:768px){.skills-categories{grid-template-columns:1fr;gap:1.5rem}}@media (max-width:480px){.skills-categories{gap:1rem}}.skill-category{background:#f8fafc;border-top:4px solid #0ea5e9;border-radius:8px;padding:2rem}@media (max-width:480px){.skill-category{padding:1.5rem}}.skill-category h3{color:#1e293b;margin-bottom:1rem;font-size:1.25rem;font-weight:700}@media (max-width:480px){.skill-category h3{font-size:1.125rem}}.skill-category ul{padding:0;list-style:none}.skill-category li{color:#475569;margin-bottom:.5rem;padding-left:1rem;font-size:.95rem;position:relative}@media (max-width:480px){.skill-category li{margin-bottom:.4rem;font-size:.875rem}}.skill-category li:before{content:"•";color:#0ea5e9;position:absolute;left:0}.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}.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}.mobile-project-nav{justify-content:space-between;gap:1rem;margin-bottom:1rem;display:flex}.mobile-nav-btn{color:#475569;cursor:pointer;background:#fff;border:2px solid #e2e8f0;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:.5rem;max-width:120px;padding:.75rem 1rem;font-weight:500;transition:all .2s;display:flex;box-shadow:0 2px 4px #0000001a}.mobile-nav-btn:hover{color:#0ea5e9;background:#f8fafc;border-color:#0ea5e9;box-shadow:0 4px 8px #00000026}.mobile-nav-btn:active{transform:scale(.98)}.mobile-nav-btn svg{transition:transform .2s}.mobile-nav-btn:hover svg{transform:translate(2px)}.mobile-nav-prev:hover svg{transform:translate(-2px)}@media (max-width:480px){.mobile-nav-btn{max-width:100px;padding:.625rem .75rem;font-size:.875rem}.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}.project-card{border-radius:8px}.project-title{font-size:1.125rem;line-height:1.3}.form-group input,.form-group textarea{font-size:16px}.mobile-project-nav{gap:.75rem;margin-bottom:1.5rem}.mobile-nav-btn{border-radius:6px;padding:.75rem .875rem;font-size:.9rem}}@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}.project-card{margin:0}.project-info{padding:.75rem}.mobile-nav-btn{gap:.25rem;padding:.5rem .75rem;font-size:.8rem}.mobile-nav-btn svg{width:16px;height:16px}}@media (min-width:768px) and (max-width:1024px){.hero-content{gap:3rem;padding:0 2rem}.project-card{max-width:95%;height:480px}.container{padding:0 1.5rem}.section-title{font-size:2.25rem}}@media (hover:none) and (pointer:coarse){.btn,button,.mobile-nav-btn,.indicator{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}
