@import "https://fonts.googleapis.com/css2?family=Fredoka:wght@400;500;600;700&family=Nunito:wght@400;600;700&display=swap";
:root{--cream:#fef9f0;--brown-light:#e8d4c0;--brown-dark:#8b6f47;--tan:#d4b5a0;--grass-green:#a4c86f;--grass-dark:#2c3e1f;--sky-blue:#87ceeb;--pink:#5b9bd5;--accent-pink:#b3d9f2;--accent-orange:#ffb347;--text-primary:#2c2c2c;--text-dim:#666;--bg-primary:#fef9f0;--bg-secondary:#f5f0e8;--border-light:#e0d5c8;--accent:#a4c86f;--accent-glow:#a4c86f80;--shadow-light:0 2px 8px #00000014;--shadow-medium:0 8px 24px #0000001f}[data-theme=night]{--cream:#1a1a1a;--brown-light:#2d2d2d;--brown-dark:#404040;--tan:#333;--bg-primary:#0f0f0f;--bg-secondary:#1a1a1a;--border-light:#333;--text-primary:#e8e8e8;--text-dim:#a0a0a0;--sky-blue:#4a7c7e}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:linear-gradient(135deg, var(--bg-primary) 0%, var(--bg-secondary) 100%);color:var(--text-primary);min-height:100vh;font-family:Nunito,Fredoka,sans-serif;line-height:1.6}nav{background:linear-gradient(180deg, var(--cream) 0%, #fef9f0f2 100%);border-bottom:3px solid var(--grass-green);z-index:999;position:sticky;top:0;box-shadow:0 2px 12px #00000014}.nav-container{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:16px 40px;display:flex}.logo{color:var(--grass-dark);letter-spacing:.5px;font-family:Fredoka,sans-serif;font-size:20px;font-weight:700;text-decoration:none;transition:all .2s}.logo:hover{color:var(--accent);text-shadow:0 0 8px var(--accent-glow)}nav ul{align-items:center;gap:32px;list-style:none;display:flex}nav ul li a{color:var(--text-primary);padding:8px 0;font-size:14px;font-weight:600;text-decoration:none;transition:all .2s;position:relative}nav ul li a:before{content:"";background:var(--accent);width:0;height:2px;transition:width .2s;position:absolute;bottom:0;left:0}nav ul li a:hover{color:var(--accent)}nav ul li a:hover:before{width:100%}.hero{background:linear-gradient(180deg, var(--bg-primary) 0%, var(--bg-secondary) 100%);align-items:center;min-height:90vh;padding:60px 40px;display:flex;position:relative;overflow:hidden}.floating-elements{pointer-events:none;position:absolute;inset:0}.cloud{opacity:.6;font-size:40px;animation:4s ease-in-out infinite float;position:absolute}.cloud1{animation-delay:0s;top:20%;left:10%}.cloud2{animation-delay:2s;top:40%;right:15%}.butterfly{font-size:24px;animation:3s ease-in-out infinite float;position:absolute}.butterfly1{animation-delay:0s;top:30%;left:20%}.butterfly2{animation-delay:1s;top:50%;right:20%}.butterfly3{animation-delay:.5s;bottom:30%;left:50%}.hero-content{z-index:1;grid-template-columns:1fr 1fr;align-items:center;gap:60px;width:100%;max-width:1200px;margin:0 auto;display:grid;position:relative}.hero-text{flex-direction:column;gap:20px;display:flex}.hero-greeting{color:var(--accent);text-transform:uppercase;letter-spacing:2px;font-size:14px;font-weight:700}.hero-name{color:var(--text-primary);font-family:Fredoka,sans-serif;font-size:56px;font-weight:800;line-height:1.1}.hero-name span{color:var(--pink)}.hero-title{color:var(--accent);font-size:18px;font-weight:600}.hero-bio{color:var(--text-dim);max-width:500px;font-size:15px;line-height:1.8}.hero-buttons{gap:16px;margin-top:12px;display:flex}.hero-image-frame{background:linear-gradient(135deg, var(--tan) 0%, var(--brown-light) 100%);border:8px solid var(--brown-dark);box-shadow:var(--shadow-medium), inset 0 0 10px #0000001a;border-radius:20px;padding:12px}.hero-image-frame img{aspect-ratio:1;object-fit:cover;filter:brightness(1.05);border-radius:12px;width:100%}.btn{cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:12px 28px;font-family:Fredoka,sans-serif;font-size:14px;font-weight:700;text-decoration:none;transition:all .2s;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--grass-green) 0%, var(--accent) 100%);color:#fff;box-shadow:0 4px 12px #a4c86f4d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px #a4c86f66}.btn-secondary{background:linear-gradient(135deg, var(--brown-light) 0%, var(--tan) 100%);color:var(--brown-dark);border:2px solid var(--brown-dark)}.btn-secondary:hover{background:linear-gradient(135deg, var(--tan) 0%, var(--brown-light) 100%);transform:translateY(-2px)}.section{z-index:1;padding:100px 0;position:relative}.container{max-width:1200px;margin:0 auto;padding:0 40px}.section-header{text-align:center;margin-bottom:60px}.section-header h2{color:var(--grass-dark);margin-bottom:12px;font-family:Fredoka,sans-serif;font-size:40px;font-weight:800}.section-header p{color:var(--text-dim);font-size:16px}.section-icon{margin-left:8px;font-size:40px}.about-content{grid-template-columns:1.5fr 1fr;align-items:center;gap:60px;display:grid}.dialogue-box{border:3px solid var(--grass-green);background:linear-gradient(135deg,#a4c86f0d 0%,#98fb980d 100%);border-radius:20px;padding:32px;box-shadow:0 8px 24px #00000014}.dialogue-body{flex-direction:column;gap:16px;display:flex}.dialogue-title{color:var(--grass-dark);font-family:Fredoka,sans-serif;font-size:22px;font-weight:700}.dialogue-body p{color:var(--text-dim);font-size:15px;line-height:1.8}.stats-grid{grid-template-columns:repeat(2,1fr);gap:20px;margin-top:20px;display:grid}.stat-box{background:linear-gradient(135deg, var(--accent-pink) 20%, #b3d9f24d 100%);border:2px solid var(--pink);text-align:center;border-radius:12px;padding:16px;box-shadow:inset 0 1px #fff3}.stat-value{color:var(--grass-dark);font-size:28px;font-weight:800;display:block}.stat-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.about-image{background:linear-gradient(135deg, var(--tan) 0%, var(--brown-light) 100%);border:8px solid var(--brown-dark);box-shadow:var(--shadow-medium), inset 0 0 10px #0000001a;border-radius:20px;padding:12px;animation:3s ease-in-out infinite float;position:relative}.about-image img{aspect-ratio:1;object-fit:cover;filter:brightness(1.05);border-radius:12px;width:100%}.collectible-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px;margin-bottom:40px;display:grid}.collectible-item{background:linear-gradient(135deg, var(--tan) 0%, var(--brown-light) 100%);border:3px solid var(--brown-dark);text-align:center;cursor:pointer;border-radius:16px;padding:20px;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 4px 12px #0000001a}.collectible-item:hover{border-color:var(--grass-green);transform:translateY(-12px)scale(1.05);box-shadow:0 12px 28px #a4c86f4d}.collectible-icon{margin-bottom:12px;font-size:48px;display:block}.collectible-name{color:var(--grass-dark);margin-bottom:8px;font-family:Fredoka,sans-serif;font-size:16px;font-weight:700}.collectible-desc{color:var(--text-dim);margin-bottom:12px;font-size:13px;line-height:1.5}.collectible-tag{background:linear-gradient(135deg, var(--accent-pink) 20%, #b3d9f266 100%);color:var(--pink);border:1px solid var(--pink);text-transform:uppercase;letter-spacing:.3px;border-radius:8px;padding:4px 12px;font-size:11px;font-weight:600;display:inline-block}.skills-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;display:grid}.skill-card{border:2px solid var(--grass-green);text-align:center;background:linear-gradient(135deg,#a4c86f1a 0%,#98fb980d 100%);border-radius:12px;padding:20px}.skill-name{color:var(--grass-dark);margin-bottom:12px;font-size:15px;font-weight:700}.skill-bar{background:var(--border-light);border-radius:4px;height:8px;margin-bottom:8px;overflow:hidden;box-shadow:inset 0 1px 2px #0000001a}.skill-bar-fill{background:linear-gradient(90deg, var(--grass-green) 0%, var(--accent) 100%);border-radius:4px;height:100%;animation:.8s ease-out slideInRight}.skill-level{color:var(--text-dim);font-size:12px;font-weight:600}.contact-section{background:linear-gradient(135deg, var(--bg-primary) 0%, #a4c86f0d 100%)}.contact-grid{grid-template-columns:1fr 1fr;align-items:start;gap:40px;display:grid}.letter-box{background:linear-gradient(135deg, var(--tan) 0%, var(--brown-light) 100%);border:8px solid var(--brown-dark);box-shadow:var(--shadow-medium), inset 0 1px 0 #ffffff4d;border-radius:16px;padding:32px}.letter-content h3{color:var(--brown-dark);margin-bottom:12px;font-family:Fredoka,sans-serif;font-size:20px;font-weight:700}.letter-content p{color:var(--text-dim);margin-bottom:16px;font-size:14px;line-height:1.8}.contact-info{flex-direction:column;gap:16px;margin-top:20px;display:flex}.contact-item{align-items:flex-start;gap:12px;display:flex}.contact-icon{min-width:32px;font-size:24px}.contact-text{flex:1}.contact-text strong{color:var(--grass-dark);text-transform:uppercase;letter-spacing:.3px;font-size:13px;display:block}.contact-text p{color:var(--text-dim);margin:4px 0 0;font-size:14px}.form-box{background:linear-gradient(135deg, var(--tan) 0%, var(--brown-light) 100%);border:8px solid var(--brown-dark);box-shadow:var(--shadow-medium), inset 0 1px 0 #ffffff4d;border-radius:16px;padding:32px}.form-group{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.form-group label{color:var(--brown-dark);text-transform:uppercase;letter-spacing:.3px;font-size:13px;font-weight:700}.form-group input,.form-group textarea{border:2px solid var(--border-light);color:var(--text-primary);background:#ffffffb3;border-radius:8px;padding:12px 16px;font-family:Nunito,sans-serif;font-size:14px;transition:all .2s}.form-group input:focus,.form-group textarea:focus{border-color:var(--grass-green);outline:none;box-shadow:0 0 0 3px #a4c86f1a}.form-group textarea{resize:vertical;min-height:120px}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@keyframes bounce{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{width:0%}to{width:100%}}.modal-overlay{z-index:1000;opacity:0;background:#000000b3;justify-content:center;align-items:center;transition:opacity .3s ease-out;display:none;position:fixed;inset:0}.modal-overlay.active{opacity:1;display:flex}.modal-content-large{background:linear-gradient(135deg, var(--tan) 0%, var(--brown-light) 100%);border:8px solid var(--brown-dark);border-radius:24px;width:90%;max-width:800px;max-height:85vh;padding:32px;animation:.4s cubic-bezier(.34,1.56,.64,1) slideInUp;position:relative;overflow-y:auto;box-shadow:0 20px 60px #0006,inset 0 1px #ffffff1a}.modal-close{background:var(--grass-green);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:24px;font-weight:700;transition:all .2s;display:flex;position:absolute;top:20px;right:20px}.modal-close:hover{background:var(--grass-dark);transform:scale(1.1)}.modal-container{grid-template-columns:1fr 1fr;align-items:start;gap:32px;display:grid}.modal-image-section{justify-content:center;align-items:center;display:flex}.modal-image-frame{aspect-ratio:4/3;background:linear-gradient(135deg, var(--cream) 0%, #a4c86f1a 100%);border:3px solid var(--border-light);border-radius:16px;justify-content:center;align-items:center;width:100%;padding:8px;display:flex;overflow:hidden;box-shadow:inset 0 2px 8px #0000001a}.modal-image-placeholder{background:linear-gradient(135deg,#a4c86f33,#ff69b41a);border-radius:12px;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.modal-info-section{flex-direction:column;gap:20px;display:flex}.modal-header{flex-direction:column;gap:12px;display:flex}.modal-title{color:var(--grass-dark);margin:0;font-family:Fredoka,sans-serif;font-size:28px;font-weight:700}.modal-description{color:var(--text-dim);font-size:14px;line-height:1.6}.modal-tech{flex-direction:column;gap:12px;display:flex}.modal-tech-label{text-transform:uppercase;letter-spacing:.5px;color:var(--grass-dark);font-size:12px;font-weight:600}.modal-tech-items{flex-wrap:wrap;gap:8px;display:flex}.tech-badge{border:1px solid var(--grass-green);color:var(--grass-dark);white-space:nowrap;background:linear-gradient(135deg,#a4c86f4d,#98fb9833);border-radius:16px;padding:6px 12px;font-size:12px;font-weight:600}.modal-buttons{flex-direction:column;gap:10px;margin-top:12px;display:flex}.modal-buttons .btn{text-align:center;cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;padding:12px 16px;font-size:14px;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}@media (max-width:992px){.hero-content,.about-content,.contact-grid,.modal-container{grid-template-columns:1fr}}@media (max-width:768px){.hero-name{font-size:40px}.section{padding:60px 0}.nav-container{padding:12px 20px}nav ul{gap:16px;font-size:12px}.section-header h2{font-size:32px}.stats-grid{grid-template-columns:1fr}.modal-content-large{max-width:95%;padding:24px}.modal-title{font-size:22px}.modal-buttons{flex-flow:wrap}.modal-buttons .btn{flex:1;min-width:120px}.collectible-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}.testimonial-section{background:linear-gradient(135deg, var(--bg-primary) 0%, var(--bg-secondary) 100%);padding:60px 0}.testimonial-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-top:40px;display:grid}.testimonial-card{background:var(--bg-secondary);border:2px solid var(--border-light);cursor:pointer;border-radius:12px;padding:24px;transition:all .3s;position:relative;overflow:hidden}.testimonial-card:before{content:"";background:linear-gradient(90deg, var(--pink), var(--accent-orange));height:4px;position:absolute;top:0;left:0;right:0}.testimonial-card:hover{border-color:var(--grass-green);transform:translateY(-8px);box-shadow:0 12px 32px #a4c86f33}.testimonial-header{align-items:flex-start;gap:12px;margin-bottom:16px;display:flex}.testimonial-avatar{font-size:32px}.testimonial-info h4{color:var(--text-primary);margin-bottom:4px;font-size:14px;font-weight:600}.testimonial-info p{color:var(--grass-green);font-size:12px}.testimonial-content{color:var(--text-dim);margin-bottom:12px;font-size:14px;font-style:italic;line-height:1.6}.testimonial-emoji{text-align:right;font-size:20px}.timeline-section{background:var(--bg-primary);padding:60px 0}.timeline-container{padding:40px 0;position:relative}.timeline-container:before{content:"";background:var(--grass-green);width:2px;position:absolute;top:0;bottom:0;left:50%;transform:translate(-1px)}.timeline-item{margin-bottom:50px;position:relative}.timeline-left .timeline-content{text-align:right;margin-left:0;margin-right:52%}.timeline-right .timeline-content{margin-left:52%;margin-right:0}.timeline-marker{z-index:10;align-items:center;gap:12px;display:flex;position:absolute;top:0;left:50%;transform:translate(-50%)}.timeline-icon{font-size:28px}.timeline-year{background:var(--grass-green);color:#fff;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:700}.timeline-body{background:var(--bg-secondary);border:2px solid var(--border-light);cursor:pointer;border-radius:8px;padding:16px 20px;transition:all .3s}.timeline-body:hover{border-color:var(--grass-green);transform:scale(1.02);box-shadow:0 8px 20px #a4c86f26}.timeline-body h4{color:var(--grass-green);margin-bottom:8px;font-size:16px}.timeline-preview{color:var(--text-dim);font-size:13px}.timeline-description{color:var(--text-primary);font-size:13px;animation:.3s slideInUp}.timeline-badge{font-size:20px;animation:.5s ease-in-out bounce;position:absolute;top:-10px;left:50%;transform:translate(-50%)}.milestone{transform:scale(1.05)}.blog-section{background:linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-primary) 100%);padding:60px 0}.blog-categories{flex-wrap:wrap;justify-content:center;gap:12px;margin:32px 0;display:flex}.category-btn{background:var(--bg-secondary);border:2px solid var(--border-light);color:var(--text-primary);cursor:pointer;border-radius:20px;padding:8px 16px;font-size:13px;font-weight:500;transition:all .3s}.category-btn:hover{border-color:var(--grass-green);transform:translateY(-2px)}.category-btn.active{background:var(--grass-green);color:#fff;transform:scale(1.05)}.blog-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px;margin-top:40px;display:grid}.blog-card{background:var(--bg-primary);border:2px solid var(--border-light);cursor:pointer;border-radius:12px;flex-direction:column;padding:24px;transition:all .3s;display:flex}.blog-card:hover{border-color:var(--grass-green);transform:translateY(-8px);box-shadow:0 12px 32px #a4c86f33}.blog-icon{margin-bottom:16px;font-size:32px}.blog-card h3{color:var(--text-primary);margin-bottom:12px;font-size:16px;line-height:1.4}.blog-excerpt{color:var(--text-dim);flex-grow:1;margin-bottom:16px;font-size:13px;line-height:1.6}.blog-meta{gap:12px;margin-bottom:16px;font-size:12px;display:flex}.blog-category{background:var(--accent-pink);color:var(--grass-dark);border-radius:12px;padding:4px 12px;font-weight:500}.blog-readtime{color:var(--text-dim)}.blog-footer{border-top:1px solid var(--border-light);justify-content:space-between;align-items:center;padding-top:12px;display:flex}.blog-date{color:var(--text-dim);font-size:12px}.blog-read-btn{color:var(--grass-green);cursor:pointer;background:0 0;border:none;font-size:13px;font-weight:600;transition:all .3s}.blog-read-btn:hover{color:var(--grass-dark);transform:translate(4px)}.blog-empty{text-align:center;color:var(--text-dim);padding:60px 20px}.quick-links{flex-wrap:wrap;gap:12px;margin-top:20px;display:flex}.link-btn{background:var(--grass-green);color:#fff;border-radius:8px;padding:8px 14px;font-size:13px;font-weight:500;text-decoration:none;transition:all .3s;display:inline-block}.link-btn:hover{background:var(--grass-dark);transform:translateY(-2px);box-shadow:0 8px 16px #a4c86f4d}.info-grid{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:8px;grid-template-columns:repeat(2,1fr);gap:16px;margin:20px 0;padding:16px;display:grid}.info-item{flex-direction:column;display:flex}.info-label{color:var(--grass-green);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.info-value{color:var(--text-primary);margin-top:4px;font-size:13px;font-weight:600}.skills-section{background:linear-gradient(135deg, var(--bg-primary) 0%, var(--bg-secondary) 100%);padding:60px 0}.skills-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:20px;margin-top:40px;display:grid}.skill-card{background:var(--bg-secondary);border:2px solid var(--border-light);text-align:center;border-radius:12px;padding:20px;transition:all .3s}.skill-card:hover{border-color:var(--grass-green);transform:translateY(-8px);box-shadow:0 12px 24px #a4c86f33}.skill-icon{margin-bottom:12px;font-size:32px;display:block}.skill-name{color:var(--text-primary);margin-bottom:8px;font-size:13px;font-weight:600;display:block}.skill-bar{background:var(--border-light);border-radius:2px;height:4px;margin-bottom:8px;overflow:hidden}.skill-fill{background:linear-gradient(90deg, var(--grass-green), var(--accent-pink));height:100%;transition:width .4s}.skill-percentage{color:var(--grass-green);font-size:12px;font-weight:700}.contact-section{background:var(--bg-primary);padding:60px 0}.contact-content{grid-template-columns:1fr 1fr;gap:40px;margin-top:40px;display:grid}.contact-info{flex-direction:column;gap:24px;display:flex}.contact-item{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:8px;align-items:flex-start;gap:16px;padding:16px;transition:all .3s;display:flex}.contact-item:hover{border-color:var(--grass-green);transform:translate(4px)}.contact-icon{flex-shrink:0;font-size:24px}.contact-item h4{color:var(--text-primary);margin-bottom:4px;font-size:14px}.contact-item a{color:var(--grass-green);font-size:13px;text-decoration:none;transition:color .3s}.contact-item a:hover{color:var(--grass-dark);text-decoration:underline}@media (max-width:992px){.timeline-container:before{left:30px}.timeline-left,.timeline-right{margin-left:0!important;margin-right:0!important}.timeline-content{margin-left:80px!important}.timeline-marker{left:30px!important}.contact-content{grid-template-columns:1fr}.info-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.blog-grid,.testimonial-grid{grid-template-columns:1fr}.skills-grid{grid-template-columns:repeat(2,1fr)}.info-grid{grid-template-columns:1fr}}@media (max-width:480px){.hero-name{font-size:28px}.section-header h2{font-size:24px}.btn{padding:10px 20px;font-size:12px}.hero-buttons{flex-direction:column}.collectible-grid,.skills-grid{grid-template-columns:1fr}.blog-categories{gap:8px}.timeline-marker{left:20px!important}.timeline-content{margin-left:60px!important}.quick-links{flex-direction:column}.link-btn{text-align:center;width:100%}}.section-title{background:linear-gradient(135deg, var(--grass-green) 0%, var(--pink) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:12px;font-size:32px;font-weight:700}.section-subtitle{color:var(--text-dim);margin-bottom:40px;font-size:15px}.projects-hero{background:linear-gradient(135deg, var(--bg-primary) 0%, var(--bg-secondary) 100%);text-align:center;border-bottom:2px solid var(--border-light);padding:80px 0 60px}.projects-hero-content{animation:.6s slideInUp}.projects-title{background:linear-gradient(135deg, var(--grass-green) 0%, var(--pink) 50%, var(--sky-blue) 100%);-webkit-text-fill-color:transparent;text-shadow:0 2px 10px #a4c86f1a;-webkit-background-clip:text;background-clip:text;margin-bottom:16px;font-size:48px;font-weight:800}.projects-subtitle{color:var(--text-dim);max-width:600px;margin:0 auto;font-size:18px}.projects-section{background:var(--bg-primary);padding:60px 0}.projects-info{text-align:center;background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:12px;margin-bottom:60px;padding:30px}.projects-info p{color:var(--text-dim);max-width:800px;margin:0 auto;font-size:15px;line-height:1.8}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:32px;margin-top:40px;display:grid}.project-card-link{color:inherit;text-decoration:none}.project-card{background:var(--bg-secondary);border:2px solid var(--border-light);cursor:pointer;border-radius:16px;transition:all .4s cubic-bezier(.34,1.56,.64,1);overflow:hidden;box-shadow:0 4px 12px #00000014}.project-card:hover{border-color:var(--grass-green);transform:translateY(-12px);box-shadow:0 16px 32px #a4c86f33}.project-image-wrapper{background:linear-gradient(135deg, var(--bg-primary) 0%, var(--bg-secondary) 100%);aspect-ratio:3/2;position:relative;overflow:hidden}.project-image-wrapper img{object-fit:cover;width:100%;height:100%;transition:transform .4s}.project-card:hover .project-image-wrapper img{transform:scale(1.08)}.project-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0;background:#a4c86fcc;justify-content:center;align-items:center;transition:opacity .4s;display:flex;position:absolute;inset:0}.project-card:hover .project-overlay{opacity:1}.view-project{color:#fff;letter-spacing:.5px;font-size:16px;font-weight:700}.project-card-content{padding:28px}.project-title{background:linear-gradient(135deg, var(--grass-green) 0%, var(--pink) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:12px;font-size:20px;font-weight:700;line-height:1.3}.project-description{color:var(--text-dim);line-clamp:2;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:16px;font-size:14px;line-height:1.6;display:-webkit-box;overflow:hidden}.tech-tags{flex-wrap:wrap;gap:8px;display:flex}.tech-tag{background:var(--accent-pink);color:#fff;letter-spacing:.3px;border-radius:8px;padding:4px 12px;font-size:12px;font-weight:600;transition:all .3s;display:inline-block}.tech-tag:hover{background:linear-gradient(135deg, var(--grass-green), var(--pink));transform:scale(1.05)}@media (max-width:992px){.projects-title{font-size:36px}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}}@media (max-width:768px){.projects-hero{padding:60px 0 40px}.projects-title{font-size:32px}.projects-grid{grid-template-columns:1fr}.project-card-content{padding:20px}}
