@charset "UTF-8";@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700&display=swap";.header[data-v-ffe88d6e]{line-height:1.5;max-height:100vh;padding:1rem}.logo[data-v-ffe88d6e]{display:block;margin:0 auto 2rem;-webkit-user-select:none;user-select:none}.wrapper[data-v-ffe88d6e]{max-width:960px;margin:0 auto}nav[data-v-ffe88d6e]{width:100%;font-size:12px;text-align:center;margin-top:2rem}.nav-link[data-v-ffe88d6e]{display:inline-block;padding:0 1rem;border-left:1px solid var(--color-border);color:var(--color-text);text-decoration:none;transition:color .3s ease,background-color .3s ease}.nav-link[data-v-ffe88d6e]:first-of-type{border-left:0}.nav-link[data-v-ffe88d6e]:hover{color:var(--color-primary, #0366d6);background-color:transparent}.active[data-v-ffe88d6e]{font-weight:600;color:var(--color-primary, #0366d6)}@media (min-width: 1024px){.header[data-v-ffe88d6e]{display:flex;align-items:center;padding-right:calc(var(--section-gap) / 2)}.logo[data-v-ffe88d6e]{margin:0 2rem 0 0}.wrapper[data-v-ffe88d6e]{display:flex;align-items:flex-start;flex-wrap:wrap;justify-content:space-between}nav[data-v-ffe88d6e]{text-align:left;margin-left:-1rem;font-size:1rem;padding:1rem 0;margin-top:1rem}}.layout[data-v-36f72444]{display:flex;flex-direction:column;min-height:100vh;color:#273238;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Tahoma,Geneva,Verdana,sans-serif;scroll-behavior:smooth;padding-top:72px}.header[data-v-36f72444]{background:transparent;padding:1.25rem 0;position:fixed;top:0;left:0;right:0;z-index:1100;display:flex;justify-content:center;transition:background-color .35s ease,box-shadow .35s ease,padding .35s ease,transform .3s ease;border-radius:12px;transform:translateY(0)}.header.scrolled[data-v-36f72444]{padding:.75rem 0;transform:translateY(-6px)}.nav[data-v-36f72444]{width:80%;max-width:1100px;background:linear-gradient(135deg,#4a6337 1%,#344731 99%);border-radius:10px;display:flex;align-items:center;justify-content:space-between;padding:.4rem 2rem;font-size:.85rem;box-shadow:0 4px 20px #5e7d3a33;transition:background-color .3s ease,box-shadow .3s ease}.nav[data-v-36f72444]:hover{background:linear-gradient(135deg,#819c68,#344731);box-shadow:0 6px 28px #5e7d3a4d}.logo[data-v-36f72444]{display:flex;align-items:center;font-weight:700;font-size:1.3rem;color:#fff;text-decoration:none;letter-spacing:1.2px;-webkit-user-select:none;user-select:none;position:relative;padding-bottom:6px;transition:color .3s ease}.logo[data-v-36f72444]:hover,.logo[data-v-36f72444]:focus{color:#b3c79b;outline:none}.logo[data-v-36f72444]:after{content:"";position:absolute;left:0;bottom:0;width:0%;height:3px;background-color:#b3c79b;transition:width .35s ease;border-radius:2px}.logo[data-v-36f72444]:hover:after,.logo[data-v-36f72444]:focus:after{width:100%}.icon-dev[data-v-36f72444]{width:26px;height:26px;margin-right:10px;stroke:#fff;transition:stroke .3s ease,transform .3s ease;-webkit-user-select:none;user-select:none}.logo:hover .icon-dev[data-v-36f72444],.logo:focus .icon-dev[data-v-36f72444]{stroke:#b3c79b;transform:rotate(10deg) scale(1.1)}.nav-items[data-v-36f72444]{list-style:none;display:flex;gap:2.2rem;margin:0;padding:0}.nav-items li a[data-v-36f72444]{color:#fff;font-weight:600;text-decoration:none;position:relative;padding:.4rem 0;transition:color .3s ease,transform .25s ease}.nav-items li a[data-v-36f72444]:after{content:"";position:absolute;left:0;bottom:-6px;width:0%;height:3px;background-color:#b3c79b;transition:width .35s ease;border-radius:2px}.nav-items li a[data-v-36f72444]:hover,.nav-items li a[data-v-36f72444]:focus{color:#b3c79b;outline:none;transform:translateY(-3px)}.nav-items li a[data-v-36f72444]:hover:after,.nav-items li a[data-v-36f72444]:focus:after{width:100%}.main-content[data-v-36f72444]{flex-grow:1;padding:1rem;max-width:100%;margin:auto;background:#fff;border-radius:16px;animation:fadeInUp-36f72444 .7s cubic-bezier(.25,.8,.25,1) forwards;transition:box-shadow .4s ease,transform .3s ease,filter .35s ease}.main-content[data-v-36f72444]:hover{transform:translateY(-8px);filter:brightness(1.04)}.footer[data-v-36f72444]{background:#e1e8ef;color:#929999;padding:1.5rem 2rem;text-align:center;font-size:.9rem;-webkit-user-select:none;user-select:none;box-shadow:inset 0 1px #c8d2df;transition:background-color .3s ease}.footer[data-v-36f72444]:hover{background-color:#edf1f5}@keyframes fadeInUp-36f72444{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.nav[data-v-36f72444]{flex-direction:column;gap:.75rem;padding:1rem 2rem;width:90%}.nav-items[data-v-36f72444]{flex-wrap:wrap;justify-content:center;gap:1.25rem}.logo[data-v-36f72444]{font-size:1.5rem}.main-content[data-v-36f72444]{padding:2rem 1.25rem;border-radius:12px;margin:2rem auto 4rem}.footer[data-v-36f72444]{padding:1rem}}[v-cloak][data-v-4c0cdcd1]{display:none}.content[data-v-4c0cdcd1]{max-width:100%;margin:2rem auto;padding:0 1rem;font-family:Inter,sans-serif;color:#273238;line-height:1.45;font-size:.85rem;transition:color .3s ease,background-color .3s ease}.loader-container[data-v-4c0cdcd1]{display:flex;justify-content:center;align-items:center;height:80vh}.loader[data-v-4c0cdcd1]{animation:rotate-4c0cdcd1 2s linear infinite;width:36px;height:36px;transition:transform .3s ease}.loader[data-v-4c0cdcd1]:hover{transform:scale(1.1)}.loader .path[data-v-4c0cdcd1]{stroke:#5e7d3a;stroke-linecap:round;animation:dash-4c0cdcd1 1.5s ease-in-out infinite}@keyframes rotate-4c0cdcd1{to{transform:rotate(360deg)}}@keyframes dash-4c0cdcd1{0%{stroke-dasharray:1,150;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-35}to{stroke-dasharray:90,150;stroke-dashoffset:-124}}.section-header[data-v-4c0cdcd1]{display:flex;align-items:center;gap:.5rem;margin-bottom:.7rem;color:#344731}.section-header svg.icon-section[data-v-4c0cdcd1]{width:18px;height:18px;fill:#5e7d3a;transition:fill .3s ease}.section-header:hover svg.icon-section[data-v-4c0cdcd1]{fill:#6a8052}h1[data-v-4c0cdcd1],h2[data-v-4c0cdcd1],h3[data-v-4c0cdcd1]{font-weight:700;color:#273238;transition:color .3s ease}h1[data-v-4c0cdcd1]{font-size:1.8rem;margin-bottom:.4rem}h2[data-v-4c0cdcd1]{font-size:1.3rem;margin-bottom:.4rem}h3[data-v-4c0cdcd1]{font-size:1rem;margin-bottom:.2rem}h1[data-v-4c0cdcd1]:hover,h2[data-v-4c0cdcd1]:hover,h3[data-v-4c0cdcd1]:hover{color:#5e7d3a;cursor:default}.intro[data-v-4c0cdcd1]{text-align:center;margin-bottom:1em;padding:1em 1rem;border-radius:12px;margin-left:auto;margin-right:auto}.intro .section-header[data-v-4c0cdcd1]{display:flex;flex-direction:column;align-items:center;gap:.25rem;margin-bottom:1.2rem}.intro .section-header h1[data-v-4c0cdcd1]{display:flex;align-items:center;gap:.5rem;font-size:1.6rem;font-weight:700;color:#344731;letter-spacing:.03em}.intro .section-header h1 i.fa-solid[data-v-4c0cdcd1]{color:#5e7d3a;font-size:1.3rem;transition:color .3s ease}.intro .section-header h1:hover i.fa-solid[data-v-4c0cdcd1]{color:#6a8052}.intro .section-header .subtitle[data-v-4c0cdcd1]{font-size:1rem;font-weight:600;color:#6a8052;display:flex;align-items:center;gap:.4rem}.intro .section-header .subtitle i.fa-solid[data-v-4c0cdcd1]{font-size:1rem;color:#7c9760;transition:color .3s ease}.intro .section-header .subtitle[data-v-4c0cdcd1]:hover{color:#344731}.intro .section-header .subtitle:hover i.fa-solid[data-v-4c0cdcd1]{color:#5e7d3a}.intro .intro-text[data-v-4c0cdcd1]{max-width:800px;margin:auto;font-size:.9rem;color:#5a6459;line-height:1.4;font-weight:400;letter-spacing:.01em;transition:color .3s ease}.intro .intro-text[data-v-4c0cdcd1]:hover{color:#344731}.intro .badges[data-v-4c0cdcd1]{display:flex;justify-content:center;flex-wrap:wrap;gap:1rem;max-width:460px;margin-left:auto;margin-right:auto}.badge[data-v-4c0cdcd1]{font-size:1rem;padding:.25rem .6rem;border-radius:16px;gap:.35rem}.badge svg.icon[data-v-4c0cdcd1]{width:14px;height:14px}.badge[data-v-4c0cdcd1]:hover{box-shadow:0 5px 18px #2e7d3a40}.badge[data-v-4c0cdcd1]{display:inline-flex;align-items:center;gap:.35rem;padding:.2rem .55rem;border-radius:14px;font-weight:600;font-size:.75rem;-webkit-user-select:none;user-select:none;cursor:default;transition:background-color .3s ease,color .3s ease,box-shadow .3s ease}.badge svg.icon[data-v-4c0cdcd1]{width:14px;height:14px;fill:currentColor;transition:transform .3s ease}.badge[data-v-4c0cdcd1]:hover{box-shadow:0 4px 12px #2e7d3a40;transform:translateY(-2px)}.badge-blue[data-v-4c0cdcd1]{background-color:#5e7d3a;color:#fff}.badge-blue[data-v-4c0cdcd1]:hover{background-color:#6a8052}.badge-green[data-v-4c0cdcd1]{background-color:#344731;color:#fff}.badge-green[data-v-4c0cdcd1]:hover{background-color:#273238}.badge-red[data-v-4c0cdcd1]{background-color:#929999;color:#fff}.badge-red[data-v-4c0cdcd1]:hover{background-color:#6a8052}.tech-stack[data-v-4c0cdcd1]{max-width:800px;margin:1em auto;padding:1em;border-radius:14px;font-family:Inter,sans-serif;color:#2c3e2f;font-size:.88rem}.tech-stack .section-header[data-v-4c0cdcd1]{display:flex;align-items:center;gap:.6rem;margin-bottom:1rem}.tech-stack .section-header h2[data-v-4c0cdcd1]{font-weight:700;font-size:1.45rem;color:#5e7d3a;display:flex;align-items:center;gap:.4rem}.tech-stack .section-header h2 .icon-section[data-v-4c0cdcd1]{font-size:1.3rem;color:#7a9e48;transition:color .3s ease}.tech-stack .section-header h2:hover .icon-section[data-v-4c0cdcd1]{color:#a1c75a}.tech-stack .tech-intro[data-v-4c0cdcd1]{margin-bottom:1.5rem;font-weight:500;color:#53694b;text-align:center;max-width:600px;margin-left:auto;margin-right:auto}.tech-stack .tech-list[data-v-4c0cdcd1]{list-style:none;padding:0;display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.tech-stack .tech-item[data-v-4c0cdcd1]{display:flex;flex-direction:column;align-items:center;gap:.5rem;background:#e9f0e7;border-radius:12px;padding:.7rem 1rem;width:96px;cursor:default;color:#2c3e2f}.tech-stack .tech-item[data-v-4c0cdcd1]:hover,.tech-stack .tech-item[data-v-4c0cdcd1]:focus-visible{background-color:#d1dfc9;box-shadow:0 6px 16px #5e7d3a33;transform:translateY(-4px);outline:none}.tech-stack .tech-item img[data-v-4c0cdcd1]{width:40px;height:40px;object-fit:contain;transition:transform .3s ease}.tech-stack .tech-item:hover img[data-v-4c0cdcd1],.tech-stack .tech-item:focus-visible img[data-v-4c0cdcd1]{transform:scale(1.15)}.tech-stack .tech-item span[data-v-4c0cdcd1]{font-weight:600;font-size:.85rem;text-align:center;color:#4a5c3d;-webkit-user-select:none;user-select:none}@media (max-width: 768px){.tech-stack[data-v-4c0cdcd1]{padding:1.2rem 1rem}.tech-stack .section-header h2[data-v-4c0cdcd1]{font-size:1.3rem}.tech-stack .tech-list[data-v-4c0cdcd1]{gap:.8rem}.tech-stack .tech-item[data-v-4c0cdcd1]{width:80px}.tech-stack .tech-item img[data-v-4c0cdcd1]{width:32px;height:32px}.tech-stack .tech-item span[data-v-4c0cdcd1]{font-size:.8rem}}.projects[data-v-4c0cdcd1]{max-width:900px;margin:3rem auto 2.5rem;padding:0 1rem;font-family:Inter,sans-serif}.projects .section-header[data-v-4c0cdcd1]{display:flex;align-items:center;gap:.55rem;margin-bottom:1.4rem}.projects .section-header h2[data-v-4c0cdcd1]{font-weight:700;font-size:1.5rem;color:#5e7d3a;display:flex;align-items:center;gap:.5rem}.projects .section-header h2 .icon-section[data-v-4c0cdcd1]{font-size:1.3rem;color:#7a9e48;transition:color .3s ease}.projects .section-header h2:hover .icon-section[data-v-4c0cdcd1]{color:#a1c75a}.projects .project-list[data-v-4c0cdcd1]{list-style:none;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.6rem}.projects .project-item[data-v-4c0cdcd1]{background:#f9faf8;border-radius:14px;box-shadow:0 4px 18px #2e7d3a26;transition:box-shadow .3s ease,transform .3s ease;overflow:hidden}.projects .project-item[data-v-4c0cdcd1]:hover,.projects .project-item[data-v-4c0cdcd1]:focus-within{box-shadow:0 8px 28px #2e7d3a4d;transform:translateY(-4px);outline:none}.projects .project-item a.project-link[data-v-4c0cdcd1]{display:flex;flex-direction:column;color:#344731;text-decoration:none;height:100%;transition:color .3s ease}.projects .project-item a.project-link[data-v-4c0cdcd1]:hover,.projects .project-item a.project-link[data-v-4c0cdcd1]:focus{color:#5e7d3a}.projects .project-item .project-image-wrapper[data-v-4c0cdcd1]{width:100%;aspect-ratio:16/9;overflow:hidden;border-radius:14px 14px 0 0;flex-shrink:0}.projects .project-item .project-image-wrapper .project-image[data-v-4c0cdcd1]{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}.projects .project-item:hover .project-image[data-v-4c0cdcd1],.projects .project-item:focus-within .project-image[data-v-4c0cdcd1]{transform:scale(1.05)}.projects .project-item .project-info[data-v-4c0cdcd1]{padding:1rem 1.3rem 1.4rem;flex-grow:1}.projects .project-item .project-info h3[data-v-4c0cdcd1]{font-size:1.15rem;margin-bottom:.3rem;font-weight:700;transition:color .3s ease}.projects .project-item .project-info p[data-v-4c0cdcd1]{font-size:.9rem;color:#6a8052;line-height:1.4}@media (max-width: 768px){.project-list[data-v-4c0cdcd1]{grid-template-columns:1fr}}.contact[data-v-4c0cdcd1]{max-width:600px;margin:2rem auto 3rem;padding:0 1rem}.contact .section-header[data-v-4c0cdcd1]{display:flex;align-items:center;gap:.6rem;margin-bottom:1.5rem}.contact .section-header h2[data-v-4c0cdcd1]{font-weight:700;font-size:1.4rem;color:#4a6b2a;display:flex;align-items:center;gap:.5rem}.contact .section-header h2 .icon-section[data-v-4c0cdcd1]{font-size:1.3rem;color:#6d9142;transition:color .3s ease}.contact .section-header h2:hover .icon-section[data-v-4c0cdcd1]{color:#8fbf56}.contact .contact-list[data-v-4c0cdcd1]{list-style:none;padding:0;display:flex;flex-wrap:wrap;gap:1.2rem;justify-content:center}.contact .contact-item[data-v-4c0cdcd1]{border-radius:10px;box-shadow:0 2px 8px #4a6b2a26;transition:box-shadow .25s ease,transform .25s ease;flex:0 1 140px}.contact .contact-item[data-v-4c0cdcd1]:hover,.contact .contact-item[data-v-4c0cdcd1]:focus-within{box-shadow:0 4px 16px #4a6b2a59;transform:translateY(-3px);outline:none}.contact .contact-item .contact-link[data-v-4c0cdcd1]{display:flex;align-items:center;gap:.8rem;padding:.6rem 1rem;color:#4a6b2a;font-weight:600;font-size:1rem;text-decoration:none;transition:color .3s ease}.contact .contact-item .contact-link[data-v-4c0cdcd1]:hover,.contact .contact-item .contact-link[data-v-4c0cdcd1]:focus{color:#739f40}.contact .contact-item .contact-icon[data-v-4c0cdcd1]{width:28px;height:28px;object-fit:contain;filter:drop-shadow(0 1px 0 rgba(0,0,0,.05));transition:filter .3s ease}.contact .contact-item .contact-link:hover .contact-icon[data-v-4c0cdcd1],.contact .contact-item .contact-link:focus .contact-icon[data-v-4c0cdcd1]{filter:drop-shadow(0 0 4px #8fbf56)}@media (max-width: 480px){.contact-list[data-v-4c0cdcd1]{justify-content:flex-start}.contact-item[data-v-4c0cdcd1]{flex:1 1 100%}}.connect[data-v-4c0cdcd1],.summary[data-v-4c0cdcd1]{max-width:650px;margin:2rem auto;padding:0 1rem;color:#3e4a20;font-size:1rem;line-height:1.6;font-weight:400}.connect .section-header[data-v-4c0cdcd1],.summary .section-header[data-v-4c0cdcd1]{display:flex;align-items:center;gap:.6rem;margin-bottom:1rem}.connect .section-header h2[data-v-4c0cdcd1],.summary .section-header h2[data-v-4c0cdcd1]{font-size:1.5rem;font-weight:700;color:#557a1f;display:flex;align-items:center;gap:.5rem}.connect .section-header h2 .icon-section[data-v-4c0cdcd1],.summary .section-header h2 .icon-section[data-v-4c0cdcd1]{font-size:1.4rem;color:#7fa230;transition:color .3s ease}.connect .section-header h2:hover .icon-section[data-v-4c0cdcd1],.summary .section-header h2:hover .icon-section[data-v-4c0cdcd1]{color:#a1c54d}.connect p[data-v-4c0cdcd1],.summary p[data-v-4c0cdcd1]{margin:0;font-size:1rem;color:#4b5c22}.connect.connect .connect-text[data-v-4c0cdcd1],.summary.connect .connect-text[data-v-4c0cdcd1]{font-weight:500}.connect.connect .connect-text strong[data-v-4c0cdcd1],.summary.connect .connect-text strong[data-v-4c0cdcd1]{color:#82b74b}.connect.summary .summary-text[data-v-4c0cdcd1],.summary.summary .summary-text[data-v-4c0cdcd1]{font-style:italic;color:#51622c}.summary-text[data-v-4c0cdcd1]{font-size:1rem;line-height:1.6;color:#2c3e50;max-width:650px;margin-top:.5rem}.section-header h2[data-v-4c0cdcd1]{display:flex;align-items:center;gap:.6rem;font-weight:700;font-size:1.6rem;color:var(--color-primary)}.about[data-v-4c0cdcd1],.tech-stack[data-v-4c0cdcd1],.skills[data-v-4c0cdcd1],.projects[data-v-4c0cdcd1],.contact[data-v-4c0cdcd1],.connect[data-v-4c0cdcd1],.summary[data-v-4c0cdcd1]{margin-bottom:2.2rem}.connect-text[data-v-4c0cdcd1]{font-size:1rem;line-height:1.6;color:#333;max-width:600px;margin-top:.5rem}.section-header h2[data-v-4c0cdcd1]{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:1.5rem;color:var(--color-primary)}.icon-section[data-v-4c0cdcd1]{color:var(--color-primary-dark)}.about[data-v-4c0cdcd1]{max-width:720px;margin:auto;padding:1em 1rem;border-radius:14px;font-family:Inter,sans-serif;color:#2d3a2e;line-height:1.5;font-size:.88rem}.about .section-header[data-v-4c0cdcd1]{display:flex;align-items:center;gap:.6rem;margin-bottom:1.2rem}.about .section-header h2[data-v-4c0cdcd1]{font-weight:700;font-size:1.45rem;color:#5e7d3a;display:flex;align-items:center;gap:.4rem}.about .section-header h2 .icon-section[data-v-4c0cdcd1]{font-size:1.3rem;color:#7a9e48;transition:color .3s ease}.about .section-header h2:hover .icon-section[data-v-4c0cdcd1]{color:#a1c75a}.about .about-text[data-v-4c0cdcd1]{margin-bottom:1rem;font-weight:500;color:#566c4a}.about .about-tech[data-v-4c0cdcd1]{list-style-type:disc;padding-left:1.5rem;margin-bottom:1.3rem;color:#4a5c3d;font-weight:500}.about .about-tech li[data-v-4c0cdcd1]{margin-bottom:.5rem}.about .about-tech li strong[data-v-4c0cdcd1]{color:#5e7d3a}.about .about-conclusion[data-v-4c0cdcd1]{font-style:italic;color:#758a5d;font-weight:600}@media (max-width: 768px){.about[data-v-4c0cdcd1]{padding:1.3rem 1rem;font-size:.82rem}.about .section-header h2[data-v-4c0cdcd1]{font-size:1.25rem}.about .about-tech li[data-v-4c0cdcd1]{margin-bottom:.4rem}}.tech-list[data-v-4c0cdcd1],.skills-list[data-v-4c0cdcd1],.project-list[data-v-4c0cdcd1],.contact-list[data-v-4c0cdcd1]{list-style:none;padding:0;display:flex;flex-wrap:wrap;gap:.85rem}.tech-item[data-v-4c0cdcd1],.contact-list li[data-v-4c0cdcd1]{display:flex;align-items:center;gap:.45rem;background:#f4f5f3;border-radius:8px;padding:.4rem .65rem;box-shadow:0 1px 4px #27323814;transition:box-shadow .4s ease,transform .3s ease;cursor:pointer;color:#273238}.tech-item[data-v-4c0cdcd1]:hover,.contact-list li[data-v-4c0cdcd1]:hover{box-shadow:0 6px 14px #27323826;transform:translateY(-3px);color:#5e7d3a}.tech-item img[data-v-4c0cdcd1],.contact-list img[data-v-4c0cdcd1]{width:20px;height:20px;object-fit:contain;transition:transform .3s ease}.tech-item:hover img[data-v-4c0cdcd1],.contact-list li:hover img[data-v-4c0cdcd1]{transform:scale(1.1)}.skills[data-v-4c0cdcd1]{max-width:700px;margin:3rem auto 2rem;padding:1.5rem 1rem;border-radius:14px;font-family:Inter,sans-serif;color:#344731;font-size:.9rem}.skills .section-header[data-v-4c0cdcd1]{display:flex;align-items:center;gap:.55rem;margin-bottom:1rem}.skills .section-header h2[data-v-4c0cdcd1]{font-weight:700;font-size:1.4rem;color:#5e7d3a;display:flex;align-items:center;gap:.4rem}.skills .section-header h2 .icon-section[data-v-4c0cdcd1]{font-size:1.25rem;color:#7a9e48;transition:color .3s ease}.skills .section-header h2:hover .icon-section[data-v-4c0cdcd1]{color:#a1c75a}.skills .skills-list[data-v-4c0cdcd1]{list-style:none;padding:0;margin:0}.skills .skills-list li[data-v-4c0cdcd1]{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;font-size:1rem;line-height:1.4;color:#2c3e50}.skills .skill-icon[data-v-4c0cdcd1]{color:#3b82f6;font-size:1.25rem;min-width:1.5rem}.skills .skills-list[data-v-4c0cdcd1]{list-style:none;padding-left:0;display:flex;flex-direction:column;gap:1rem}.skills .skills-list li[data-v-4c0cdcd1]{position:relative;padding-left:1.7rem;font-weight:600;color:#425837;line-height:1.3;cursor:default;transition:color .3s ease}.skills .skills-list li[data-v-4c0cdcd1]:focus-visible,.skills .skills-list li[data-v-4c0cdcd1]:hover{color:#5e7d3a;outline:none}.skills .skills-list li[data-v-4c0cdcd1]:before{content:"✔";position:absolute;left:0;top:50%;transform:translateY(-50%);color:#7a9e48;font-weight:900;font-size:1.1rem;-webkit-user-select:none;user-select:none}@media (max-width: 768px){.skills[data-v-4c0cdcd1]{padding:1.2rem .8rem}.skills .section-header h2[data-v-4c0cdcd1]{font-size:1.2rem}.skills .skills-list li[data-v-4c0cdcd1]{font-size:.85rem;padding-left:1.3rem}.skills .skills-list li[data-v-4c0cdcd1]:before{font-size:1rem}}.skills-list[data-v-4c0cdcd1]{flex-direction:column;max-width:600px;margin:0 auto}.skills-list li[data-v-4c0cdcd1]{margin-bottom:.45rem;font-size:.85rem;color:#6a8052;padding-left:1.3rem;position:relative;transition:color .3s ease;cursor:default}.skills-list li[data-v-4c0cdcd1]:before{content:"✓";position:absolute;left:0;color:#5e7d3a}.skills-list li[data-v-4c0cdcd1]:hover{color:#344731}.project-list[data-v-4c0cdcd1]{flex-direction:column;gap:1.6rem;max-width:800px;margin:0 auto}.project-item[data-v-4c0cdcd1]{display:flex;flex-wrap:wrap;gap:1rem;background:#fff;border-radius:8px;box-shadow:0 2px 8px #2732381a;transition:box-shadow .4s ease,transform .3s ease;cursor:pointer;color:#273238}.project-item img[data-v-4c0cdcd1]{max-width:220px;border-radius:8px 0 0 8px;object-fit:cover;flex-shrink:0;transition:transform .3s ease}.project-item:hover img[data-v-4c0cdcd1]{transform:scale(1.05)}.project-info[data-v-4c0cdcd1]{padding:1rem 1.5rem;flex:1}.project-info h3[data-v-4c0cdcd1]{margin-bottom:.3rem;font-size:1rem;transition:color .3s ease}.project-item[data-v-4c0cdcd1]{display:flex;align-items:center;gap:1rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #2732381a;transition:box-shadow .4s ease,transform .3s ease;cursor:pointer;color:#273238;padding:1rem}.project-item[data-v-4c0cdcd1]:hover{box-shadow:0 8px 22px #2732382e;transform:translateY(-5px);color:#5e7d3a}.project-image-wrapper[data-v-4c0cdcd1]{width:40px;height:40px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.project-image[data-v-4c0cdcd1]{width:32px;height:32px;border-radius:50%;object-fit:contain;transition:transform .3s ease;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.project-item:hover .project-image[data-v-4c0cdcd1]{transform:scale(1.05)}.project-info[data-v-4c0cdcd1]{flex:1;padding:.2rem 0}.project-info h3[data-v-4c0cdcd1]{margin-bottom:.2rem;font-size:1.05rem;font-weight:600;transition:color .3s ease}.project-info h3[data-v-4c0cdcd1]:hover{color:#5e7d3a}.project-info p[data-v-4c0cdcd1]{font-size:.9rem;line-height:1.4;margin:0}.contact-list a[data-v-4c0cdcd1]{display:flex;align-items:center;gap:.65rem;color:#273238;text-decoration:none;font-weight:600;transition:color .3s ease;cursor:pointer}.contact-list a[data-v-4c0cdcd1]:hover{color:#5e7d3a;text-decoration:underline}@media (max-width: 768px){.project-item[data-v-4c0cdcd1]{flex-direction:column}.project-item img[data-v-4c0cdcd1]{width:100%;border-radius:8px 8px 0 0}}.hero-banner[data-v-4c0cdcd1]{border-radius:0 0 60px 60px;background-color:transparent;display:flex;justify-content:center;align-items:center;padding:2rem 1rem}.banner-container[data-v-4c0cdcd1]{max-width:100%;width:100%;display:flex;justify-content:center;align-items:center}.banner-image[data-v-4c0cdcd1]{display:block;max-width:400px;width:100%;height:auto;margin:0 auto;border-radius:16px;object-fit:contain;transition:transform .4s ease,box-shadow .4s ease,filter .4s ease;animation:fadeSlideUp-4c0cdcd1 .8s ease-out}.banner-image[data-v-4c0cdcd1]:hover{transform:scale(1.05) translateY(-4px);filter:brightness(1.05)}@keyframes fadeSlideUp-4c0cdcd1{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background-color:#fff;color:#333;margin:0;padding:0}a{color:#0366d6;text-decoration:none}a:hover{text-decoration:underline}
