@layer base{:root{--background: 210 40% 98%;--foreground: 222 47% 11%;--card: 0 0% 100%;--primary: 250 47% 60%;--primary-foreground: 210 40% 98%;--border: 214 32% 91%;--color-border: hsl(var(--border));--color-background: hsl(var(--background));--color-foreground: hsl(var(--foreground));--color-primary: hsl(var(--primary));--color-primary-foreground: hsl(var(--primary-foreground));--color-card: hsl(var(--card))}.dark{--background: 222 47% 4%;--foreground: 213 31% 91%;--card: 222 47% 8%;--primary: 250 65% 65%;--primary-foreground: 213 31% 91%;--border: 217 33% 20%}html{scroll-behavior:smooth}body{background-color:hsl(var(--background));color:hsl(var(--foreground));transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-duration:.3s;font-feature-settings:"rlig" 1,"calt" 1;line-height:1.6}*{border-color:hsl(var(--border))}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#5a67d8,#6b46c1)}.dark ::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#93c5fd,#a78bfa)}.dark ::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#60a5fa,#8b5cf6)}#root{max-width:100%;margin:0 auto;padding:0;text-align:center}.hero{position:relative;overflow:hidden}::-moz-selection{background:linear-gradient(135deg,#667eea4d,#764ba24d);color:inherit}::selection{background:linear-gradient(135deg,#667eea4d,#764ba24d);color:inherit}*:focus{outline:2px solid #667eea;outline-offset:2px}button,a,input,textarea,select{transition:all .3s ease}}@layer utilities{@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes pulse-subtle{0%,to{opacity:1}50%{opacity:.8}}@keyframes fade-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slide-in-left{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes slide-in-right{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes scale-in{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes meteor{0%{transform:rotate(215deg) translate(0);opacity:1}70%{opacity:1}to{transform:rotate(215deg) translate(-500px);opacity:0}}@keyframes shimmer{0%{background-position:-200px 0}to{background-position:calc(200px + 100%) 0}}.animate-float{animation:float 6s ease-in-out infinite}.animate-pulse-subtle{animation:pulse-subtle 4s ease-in-out infinite}.animate-fade-in{animation:fade-in .7s ease-out forwards}.animate-slide-in-left{animation:slide-in-left .7s ease-out forwards}.animate-slide-in-right{animation:slide-in-right .7s ease-out forwards}.animate-scale-in{animation:scale-in .5s ease-out forwards}.animate-fade-in-delay-1{animation:fade-in .7s ease-out .2s forwards}.animate-fade-in-delay-2{animation:fade-in .7s ease-out .4s forwards}.animate-fade-in-delay-3{animation:fade-in .7s ease-out .6s forwards}.animate-fade-in-delay-4{animation:fade-in .7s ease-out .8s forwards}.animate-meteor{animation:meteor 5s linear infinite}.animate-shimmer{background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);background-size:200px 100%;animation:shimmer 2s infinite}.container-custom{margin-inline:auto;padding-inline:2rem}@media (min-width: 640px){.container-custom{max-width:640px}}@media (min-width: 768px){.container-custom{max-width:768px}}@media (min-width: 1024px){.container-custom{max-width:1024px}}@media (min-width: 1280px){.container-custom{max-width:1280px}}@media (min-width: 1400px){.container-custom{max-width:1400px}}.text-glow{position:relative;text-shadow:0 0 10px rgba(167,139,250,.5)}.card-hover{transition-property:transform,box-shadow;transition-duration:.3s}.card-hover:hover{transform:scale(1.02);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a}.gradient-border{position:relative;border-radius:.375rem;background:linear-gradient(to right,hsl(var(--card)),hsl(var(--card)));background-clip:padding-box;border:1px solid transparent}.cosmic-button{padding:.5rem 1.5rem;border-radius:9999px;background-color:hsl(var(--primary));color:hsl(var(--primary-foreground));font-weight:500;transition-property:all;transition-duration:.3s}.cosmic-button:hover{box-shadow:0 0 10px #8b5cf680;transform:scale(1.05)}.cosmic-button:active{transform:scale(.95)}.star{position:absolute;border-radius:9999px;background-color:#fff;box-shadow:0 0 10px 2px #fff6}.meteor{display:none}.dark .meteor{display:block;position:absolute;top:0;left:100%;width:2px;height:100px;border-radius:9999px;background:linear-gradient(to right,white,white,transparent);animation:meteor 5s linear infinite;pointer-events:none;z-index:10}.theme-toggle-button{position:fixed;top:1.25rem;left:50%;transform:translate(-50%);z-index:50;padding:.5rem;border:none;background-color:transparent;border-radius:9999px;cursor:pointer;transition:color .3s ease}.icon{width:24px;height:24px;transition:color .3s ease}.moon-icon{color:#082269}.dark .moon-icon,.sun-icon{color:#f9bc04}.app-container{min-height:100vh;background-color:hsl(var(--background));color:hsl(var(--foreground));overflow-x:hidden}.dark .navbar__link{color:#fff}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:radial-gradient(white 1px,transparent 1px),radial-gradient(white 1px,transparent 1px);background-size:50px 50px,100px 100px;background-position:0 0,25px 25px;z-index:0;opacity:.2;pointer-events:none}.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200px 100%;animation:shimmer 1.5s infinite}.dark .skeleton{background:linear-gradient(90deg,#374151 25%,#4b5563,#374151 75%);background-size:200px 100%}.glass{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}.dark .glass{background:#0000001a;border:1px solid rgba(255,255,255,.1)}.gradient-text{background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}.text-responsive{font-size:clamp(1rem,2.5vw,1.5rem)}.heading-responsive{font-size:clamp(1.5rem,4vw,3rem)}.focus-ring:focus{outline:2px solid #667eea;outline-offset:2px;border-radius:.375rem}.reveal{opacity:0;transform:translateY(30px);transition:all .6s ease}.reveal.revealed{opacity:1;transform:translateY(0)}.hover-lift{transition:transform .3s ease,box-shadow .3s ease}.hover-lift:hover{transform:translateY(-5px);box-shadow:0 10px 25px #00000026}.dark .hover-lift:hover{box-shadow:0 10px 25px #0006}}.navbar{position:fixed;top:0;width:100%;z-index:50;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:background-color .3s ease,box-shadow .3s ease}.navbar{background-color:#c0aaaa00;color:#000}.navbar__link{color:#000;text-decoration:none;margin-left:1rem;transition:color .5s ease;position:relative}.navbar__link:hover{color:#0d7cff;text-shadow:0 0 10px #0D7CFF,0 0 20px #0D7CFF,0 0 30px #0D7CFF,0 0 40px #0D7CFF;transform:scale(1.1)}html.dark .navbar{background-color:#0000005a;color:#fff}html.dark .navbar__link{color:#fff}.navbar--scrolled{box-shadow:0 2px 6px #47444400}.navbar__container{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem}.navbar__theme-toggle{margin-left:1rem}.theme-toggle-btn{background:none;border:none;cursor:pointer;padding:.5rem;margin-left:.5rem;border-radius:50%;transition:all .3s ease;position:relative;overflow:hidden}.theme-toggle-btn:hover{background-color:#667eea1a;transform:scale(1.1)}.theme-toggle-btn:active{transform:scale(.95)}.theme-toggle-btn.animating{pointer-events:none}.icon-container{position:relative;display:flex;align-items:center;justify-content:center}.sun-icon,.moon-icon{transition:all .3s ease}.sun-icon.rotate,.moon-icon.rotate{animation:rotateIcon .3s ease-in-out}@keyframes rotateIcon{0%{transform:rotate(0) scale(1)}50%{transform:rotate(180deg) scale(1.2)}to{transform:rotate(360deg) scale(1)}}.dark .theme-toggle-btn:hover{background-color:#9cc5fd1a}.navbar__menu-toggle{display:none;background:none;border:none;cursor:pointer;color:inherit}.navbar__mobile-menu{display:none;flex-direction:column;background:inherit;width:100%;padding:1rem 2rem}.navbar__mobile-menu.open{display:flex}@media (max-width: 768px){.navbar__nav-items--desktop{display:none}.navbar__menu-toggle{display:block}}.hero-section{position:relative;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding-left:1rem;padding-right:1rem;overflow-x:hidden}.hero-container{max-width:64rem;margin-left:auto;margin-right:auto;text-align:center;z-index:10}.hero-content>*+*{margin-top:1.5rem}.hero-badge{margin-bottom:2rem}.badge-text{display:inline-block;padding:.5rem 1.5rem;background:linear-gradient(135deg,#667eea1a,#764ba21a);border:1px solid rgba(102,126,234,.2);border-radius:25px;color:#667eea;font-size:.9rem;font-weight:500;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.dark .badge-text{background:linear-gradient(135deg,#667eea33,#764ba233);border-color:#667eea4d;color:#93c5fd}.hero-title{font-weight:700;font-size:2rem;letter-spacing:-.025em;line-height:1.2}@media (min-width: 768px){.hero-title{font-size:3.75rem}}.fade-in{opacity:0;animation:fadeIn 1s forwards}.fade-in-delay-1{opacity:0;animation:fadeIn 1s forwards;animation-delay:.5s}.fade-in-delay-2{opacity:0;animation:fadeIn 1s forwards;animation-delay:1s}.fade-in-delay-3{opacity:0;animation:fadeIn 1s forwards;animation-delay:1.5s}.fade-in-delay-4{opacity:0;animation:fadeIn 1s forwards;animation-delay:2s}.fade-in-delay-5{opacity:0;animation:fadeIn 1s forwards;animation-delay:2.5s}@keyframes fadeIn{to{opacity:1}}.text-primary{color:#3b82f6}.text-gradient{background:linear-gradient(90deg,#3b82f6,#9333ea);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}.highlight-text{background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;font-weight:600}.ml-2{margin-left:.5rem}.hero-subtitle{font-size:1.125rem;color:#6b7280;max-width:42rem;margin-left:auto;margin-right:auto;line-height:1.7}.dark .hero-subtitle{color:#9ca3af}.hero-stats{display:flex;justify-content:center;gap:3rem;margin:2rem 0;flex-wrap:wrap}.stat-item{display:flex;flex-direction:column;align-items:center;gap:.5rem}.stat-number{font-size:2rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}.stat-label{font-size:.9rem;color:#6b7280;font-weight:500}.dark .stat-label{color:#9ca3af}.hero-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:2rem}.cosmic-button{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:50px;font-weight:600;text-decoration:none;transition:all .3s ease;font-size:.95rem;border:2px solid transparent}.primary-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 15px #667eea4d}.primary-btn:hover{transform:translateY(-3px);box-shadow:0 8px 25px #667eea66;color:#fff}.secondary-btn{background:transparent;color:#667eea;border-color:#667eea}.secondary-btn:hover{background:#667eea;color:#fff;transform:translateY(-3px);box-shadow:0 8px 25px #667eea4d}.download-btn{background:transparent;color:#6b7280;border-color:#e5e7eb}.download-btn:hover{background:#6b7280;color:#fff;border-color:#6b7280;transform:translateY(-3px)}.dark .download-btn{border-color:#374151;color:#9ca3af}.dark .download-btn:hover{background:#9ca3af;color:#111827;border-color:#9ca3af}.scroll-indicator{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;color:#6b7280;animation:float 3s ease-in-out infinite}.scroll-text{font-size:.9rem;font-weight:500}.scroll-arrow{display:flex;justify-content:center}.arrow-down{width:2px;height:20px;background:linear-gradient(to bottom,#667eea,transparent);border-radius:1px;animation:scrollDown 2s ease-in-out infinite}@keyframes scrollDown{0%,to{transform:translateY(0);opacity:1}50%{transform:translateY(10px);opacity:.5}}@media (max-width: 768px){.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1rem}.hero-stats{gap:2rem}.stat-number{font-size:1.5rem}.hero-cta{flex-direction:column;align-items:center}.cosmic-button{width:100%;max-width:250px;justify-content:center}}@media (max-width: 480px){.hero-title{font-size:2rem}.hero-stats{gap:1.5rem}.stat-item{min-width:80px}}.about-section{padding:6rem 1rem;position:relative}.about-container{max-width:80rem;margin-left:auto;margin-right:auto}.about-title{font-size:2rem;font-weight:700;margin-bottom:3rem;text-align:center}@media (min-width: 768px){.about-title{font-size:2.25rem}}.highlight{color:var(--primary-color)}.about-grid{display:grid;grid-template-columns:1fr;gap:3rem;align-items:center}@media (min-width: 768px){.about-grid{grid-template-columns:repeat(2,1fr)}}.about-text{display:flex;flex-direction:column;gap:1.5rem}.about-subtitle{font-size:1.5rem;font-weight:600}.about-paragraph{color:var(--muted-foreground);line-height:1.5}.about-buttons{display:flex;flex-direction:column;gap:1rem;padding-top:1rem;justify-content:center}@media (min-width: 640px){.about-buttons{flex-direction:row}}.button{display:inline-block;text-decoration:none;padding:.5rem 1.5rem;border-radius:9999px;font-weight:600;text-align:center;cursor:pointer;transition:background-color .3s ease}.cosmic-button{background-color:var(--primary-color);color:#fff}.button-outline{border:1px solid var(--primary-color);color:var(--primary-color)}.button-outline:hover{background-color:var(--primary-color);color:#fff}.about-cards{display:grid;grid-template-columns:1fr;gap:1.5rem}.card{padding:1.5rem;border-radius:.5rem;background-color:var(--background-color);transition:box-shadow .3s ease;cursor:default}.card-hover:hover{box-shadow:0 4px 15px #3b82f64d}.gradient-border{border:2px solid;border-image-slice:1;border-width:2px;border-image-source:linear-gradient(90deg,#3b82f6 0%,#9333ea 100%)}.card-content{display:flex;gap:1rem;align-items:flex-start}.icon-bg{padding:.75rem;border-radius:9999px;background-color:#3b82f61a;display:flex;align-items:center;justify-content:center}.icon{width:1.5rem;height:1.5rem;color:var(--primary-color)}.card-text{text-align:left}.card-title{font-weight:600;font-size:1.125rem;margin-bottom:.25rem}.card-description{color:var(--muted-foreground);font-size:.875rem}.noto-sans-hanunoo-regular{font-family:Noto Sans Hanunoo,sans-serif;font-weight:400;font-style:normal}.contact-section{padding:6rem 1rem;max-width:80rem;margin:auto}.contact-heading{text-align:center;font-size:2.5rem;font-weight:700;margin-bottom:1rem}.contact-heading span{color:#3b82f6}.contact-subtext{text-align:center;max-width:40rem;margin:0 auto 3rem;color:#6b7280}.contact-grid{display:flex;flex-direction:column;align-items:center;gap:2rem}.contact-info-card{display:flex;flex-direction:column;gap:1.5rem;width:100%;max-width:600px}.contact-item{display:flex;align-items:center;gap:1rem}.contact-item .contact-icon{color:#3b82f6;flex-shrink:0}.contact-item h4{margin:0 0 .25rem;font-weight:600}.contact-item a,.contact-item span{color:#6b7280;transition:color .3s}.contact-item a:hover{color:#3b82f6}.contact-form-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#3b82f630;border:1px solid rgba(255,255,255,.2);border-radius:.75rem;padding:2rem;box-shadow:0 8px 30px #00000026;width:100%;max-width:600px}.contact-form-card form{display:flex;flex-direction:column;gap:1rem}.contact-form-card label{font-weight:500}.contact-form-card input,.contact-form-card textarea{background-color:#ffffffc8;border:1px solid #d1d5db;border-radius:.375rem;padding:.75rem 1rem;font-size:1rem;transition:box-shadow .3s,border-color .3s}.contact-form-card input:focus,.contact-form-card textarea:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 2px #3b82f6}.cosmic-button{background-color:#3b82f6;color:#fff;font-weight:600;font-size:1rem;border:none;border-radius:9999px;padding:.75rem 1.5rem;display:inline-flex;align-items:center;gap:.5rem;justify-content:center;cursor:pointer;transition:background-color .3s}.cosmic-button:hover{background-color:#2563eb}.cosmic-button:focus{outline:2px solid #3b82f6;outline-offset:2px}.skills-section{padding:2rem;margin:.1rem}.skills-title{font-size:2rem;margin-bottom:1rem;text-align:center}.skills-categories{display:flex;justify-content:center;margin-bottom:2rem}.skills-button{margin:0 .5rem;padding:.5rem 1rem;cursor:pointer;border:1px solid #eee;background-color:#f5f5f5;color:#000000b5;border-radius:8px;box-shadow:0 4px 15px #0003;transition:transform .3s,background-color .3s}.skills-button:hover{transform:translateY(-3px);background-color:#0000000d}.skills-button.active{background-color:#0000001a;color:#000}.dark .skills-button{background:#240eec1a;color:#fff;border:1px solid #eee;box-shadow:0 4px 15px #00000080}.dark .skills-button:hover{background-color:#ffffff0d;transform:translateY(-3px)}.dark .skills-button.active{background-color:#ffffff1a;color:#fff}.skills-grid{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.skill-card-vertical{background-color:#f5f5f5;color:#000000b5;border:1px solid #eee;border-radius:8px;width:120px;height:150px;text-align:center;padding:2rem;box-shadow:0 4px 15px #0003;transition:transform .3s;display:flex;flex-direction:column;align-items:center;justify-content:center}.skill-card-vertical:hover{transform:translateY(-5px);background-color:#0000000d}.skill-icon{font-size:5rem;margin-bottom:.5rem;color:#3984fc}.dark .skill-card-vertical{background:#240eec1a;color:#fff;box-shadow:0 4px 15px #00000080}.dark .skill-card-vertical:hover{background-color:#ffffff0d}.dark .skill-icon{color:#ffffffe9}.skill-name{font-size:1rem}.skill-name:hover{cursor:pointer}.projects-section{padding:6rem 1rem}.projects-container{max-width:1100px;margin:0 auto;text-align:center}.projects-title{font-size:2.5rem;font-weight:700;margin-bottom:1rem}.highlight{background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.projects-subtitle{max-width:600px;margin:0 auto 3rem;color:#6b7280;font-size:1.1rem;line-height:1.6}.projects-filter{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:3rem;flex-wrap:wrap}.filter-icon{color:#6b7280;display:flex;align-items:center}.filter-buttons{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}.filter-button{padding:.5rem 1.5rem;border:2px solid #e5e7eb;background:transparent;color:#6b7280;border-radius:25px;cursor:pointer;transition:all .3s ease;font-weight:500;font-size:.9rem}.filter-button:hover{border-color:#667eea;color:#667eea;transform:translateY(-2px)}.filter-button.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:transparent;color:#fff;box-shadow:0 4px 15px #667eea66}.dark .filter-button{border-color:#374151;color:#9ca3af}.dark .filter-button:hover{border-color:#667eea;color:#667eea}.dark .filter-button.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:transparent;color:#fff}.projects-grid{display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));margin-bottom:3rem}.project-card{background-color:#fff;border-radius:1rem;overflow:hidden;box-shadow:0 4px 6px #0000000d;transition:all .3s ease;position:relative;border:1px solid #f3f4f6}.project-card:hover{transform:translateY(-8px);box-shadow:0 20px 25px #0000001a}.dark .project-card{background-color:#1f2937;border-color:#374151;box-shadow:0 4px 6px #0000004d}.dark .project-card:hover{box-shadow:0 20px 25px #0006}.project-image-wrapper{height:220px;overflow:hidden;position:relative}.project-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .5s ease}.project-card:hover .project-image{transform:scale(1.1)}.featured-badge{position:absolute;top:1rem;right:1rem;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;padding:.25rem .75rem;border-radius:15px;font-size:.75rem;font-weight:600;z-index:2}.project-overlay{position:absolute;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}.project-card:hover .project-overlay{opacity:1}.project-actions{display:flex;gap:1rem;flex-direction:column}.project-action-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:25px;text-decoration:none;font-weight:500;transition:all .3s ease;font-size:.9rem}.demo-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.github-btn{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2)}.project-action-btn:hover{transform:translateY(-2px);box-shadow:0 4px 15px #0003}.project-content{padding:1.5rem;text-align:left}.project-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.project-tag{font-size:.75rem;background:linear-gradient(135deg,#e0f2fe,#b3e5fc);color:#0369a1;padding:.25rem .75rem;border-radius:15px;cursor:pointer;transition:all .3s ease;font-weight:500}.project-tag:hover{background:linear-gradient(135deg,#b3e5fc,#81d4fa);transform:scale(1.05)}.dark .project-tag{background:linear-gradient(135deg,#1e3a8a,#1e40af);color:#93c5fd}.dark .project-tag:hover{background:linear-gradient(135deg,#1e40af,#3b82f6)}.project-title{font-weight:700;font-size:1.25rem;margin-bottom:.75rem;color:#111827;line-height:1.3}.dark .project-title{color:#f9fafb}.project-description{color:#6b7280;font-size:.95rem;line-height:1.6;margin-bottom:0}.dark .project-description{color:#9ca3af}.no-projects{text-align:center;padding:3rem;color:#6b7280;font-size:1.1rem}.dark .no-projects{color:#9ca3af}.projects-footer{margin-top:3rem}.projects-button{display:inline-flex;align-items:center;gap:.5rem;padding:1rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-decoration:none;border-radius:50px;font-weight:600;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d}.projects-button:hover{transform:translateY(-3px);box-shadow:0 8px 25px #667eea66;color:#fff}@media (max-width: 768px){.projects-section{padding:4rem 1rem}.projects-title{font-size:2rem}.projects-filter{flex-direction:column;gap:1rem}.filter-buttons{width:100%;justify-content:center}.projects-grid{grid-template-columns:1fr;gap:1.5rem}.project-image-wrapper{height:200px}.project-actions{flex-direction:row}.project-action-btn{padding:.5rem 1rem;font-size:.8rem}}.footer{padding:2rem 1rem 3rem;background-color:var(--card-bg, #fff);position:relative;border-top:1px solid var(--border-color, #e5e7eb);margin-top:3rem;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center}.scroll-up-btn{padding:.5rem;border-radius:9999px;background-color:#3b82f61a;color:var(--primary-color, #3b82f6);transition:background-color .2s ease-in-out;display:inline-flex;align-items:center;justify-content:center;text-decoration:none}.scroll-up-btn:hover{background-color:#3b82f633}.social-links{padding-top:2rem;display:flex;gap:1rem;justify-content:center}.social-links a svg{height:1.5rem;width:1.5rem;color:#3b82f6;transition:color .3s}.social-links a:hover svg{color:#2563eb}.contact-form{background-color:#f9fafb;padding:2rem;border-radius:.5rem;box-shadow:0 2px 8px #0000000d}.footer{padding:1rem;text-align:center;background-color:hsl(var(--background));color:hsl(var(--foreground));position:relative}.footer-text{margin-bottom:.75rem}.social-links.centered{display:flex;justify-content:center;gap:1.5rem;margin:.5rem auto}.social-links a{color:inherit;transition:transform .3s ease,color .3s ease}.social-links a:hover{transform:scale(1.2);color:hsl(var(--primary))}.scroll-up-btn{position:fixed;right:1rem;bottom:1rem;background:hsl(var(--primary));color:hsl(var(--primary-foreground));padding:.5rem;border-radius:9999px;transition:transform .3s ease,box-shadow .3s ease;z-index:50}.scroll-up-btn:hover{transform:scale(1.1);box-shadow:0 0 10px #8b5cf680}
