.image-container{position:relative;overflow:hidden;background:#f3f4f6;border-radius:8px}.image{width:100%;height:100%;object-fit:cover;transition:opacity .3s ease,transform .3s ease}.image--loading{opacity:0}.image--error{display:none}.image-skeleton{position:absolute;top:0;left:0;width:100%;height:100%;border-radius:inherit}.image-error{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#f9fafb;color:#6b7280;border-radius:inherit}.image-error-icon{width:48px;height:48px;margin-bottom:8px;opacity:.5}.image-error-text{font-size:.875rem;text-align:center}.image-container:hover .image{transform:scale(1.05)}.app.dark .image-container{background:#374151}.app.dark .image-error{background:#1f2937;color:#9ca3af}@media (max-width: 768px){.image-error-icon{width:32px;height:32px}.image-error-text{font-size:.75rem}}.modal-backdrop{position:fixed;inset:0;background-color:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#fff;border-radius:12px;max-width:90vw;max-height:90vh;width:100%;max-width:800px;overflow:hidden;box-shadow:0 25px 50px -12px #00000040;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 2rem;border-bottom:1px solid #e5e7eb;background:#f9fafb}.modal-title{margin:0;font-size:1.5rem;font-weight:600;color:#111827}.modal-close{background:none;border:none;padding:.5rem;cursor:pointer;border-radius:6px;color:#6b7280;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.modal-close:hover{background-color:#f3f4f6;color:#374151}.modal-close:focus{outline:2px solid #3b82f6;outline-offset:2px}.modal-body{padding:2rem;overflow-y:auto;max-height:calc(90vh - 120px)}@media (max-width: 768px){.modal-backdrop{padding:.5rem}.modal-content{max-width:95vw;max-height:95vh}.modal-header{padding:1rem 1.5rem}.modal-title{font-size:1.25rem}.modal-body{padding:1.5rem;max-height:calc(95vh - 100px)}}@media (prefers-color-scheme: dark){.modal-content{background:#1f2937;color:#f9fafb}.modal-header{background:#111827;border-bottom-color:#374151}.modal-title{color:#f9fafb}.modal-close{color:#9ca3af}.modal-close:hover{background-color:#374151;color:#f3f4f6}}.project-detail{display:flex;flex-direction:column;gap:2rem}.project-detail__gallery{width:100%}.project-detail__main-image{position:relative;width:100%;height:300px;border-radius:8px;overflow:hidden;background:#f3f4f6;display:flex;align-items:center;justify-content:center}.project-detail__main-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.project-detail__image-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;color:#9ca3af;text-align:center}.project-detail__image-placeholder p{margin:.5rem 0 0;font-size:.875rem}.project-detail__nav-btn{position:absolute;top:50%;transform:translateY(-50%);background:#000000b3;color:#fff;border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;opacity:0}.project-detail__main-image:hover .project-detail__nav-btn{opacity:1}.project-detail__nav-btn:hover{background:#000000e6;transform:translateY(-50%) scale(1.1)}.project-detail__nav-btn--prev{left:1rem}.project-detail__nav-btn--next{right:1rem}.project-detail__thumbnails{display:flex;gap:.5rem;margin-top:1rem;overflow-x:auto;padding:.5rem 0}.project-detail__thumbnail{flex-shrink:0;width:60px;height:60px;border:2px solid transparent;border-radius:6px;overflow:hidden;cursor:pointer;transition:all .2s ease;background:none;padding:0}.project-detail__thumbnail.active{border-color:#3b82f6}.project-detail__thumbnail:hover{border-color:#93c5fd}.project-detail__thumbnail img{width:100%;height:100%;object-fit:cover}.project-detail__content{display:flex;flex-direction:column;gap:1.5rem}.project-detail__header{display:flex;align-items:flex-start;gap:1rem}.project-detail__title-section{display:flex;align-items:center;gap:.75rem;flex:1}.project-detail__title{margin:0;font-size:1.5rem;font-weight:600;color:#111827;line-height:1.3}.project-detail__featured-badge{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;flex-shrink:0}.project-detail__description h4,.project-detail__technologies h4{margin:0 0 .75rem;font-size:1.125rem;font-weight:600;color:#374151}.project-detail__description p{margin:0;line-height:1.6;color:#6b7280}.project-detail__tech-list{display:flex;flex-wrap:wrap;gap:.5rem}.project-detail__tech-tag{background:#eff6ff;color:#1e40af;padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:500;border:1px solid #dbeafe}.project-detail__actions{display:flex;gap:1rem;margin-top:1rem}.project-detail__action-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:8px;font-weight:500;text-decoration:none;transition:all .2s ease;cursor:pointer;border:none;font-size:.875rem}.project-detail__action-btn--primary{background:#3b82f6;color:#fff}.project-detail__action-btn--primary:hover{background:#2563eb;transform:translateY(-1px)}.project-detail__action-btn--secondary{background:#f9fafb;color:#374151;border:1px solid #d1d5db}.project-detail__action-btn--secondary:hover{background:#f3f4f6;border-color:#9ca3af;transform:translateY(-1px)}@media (max-width: 768px){.project-detail{gap:1.5rem}.project-detail__main-image{height:200px}.project-detail__header{flex-direction:column;align-items:flex-start;gap:.75rem}.project-detail__title{font-size:1.25rem}.project-detail__actions{flex-direction:column}.project-detail__action-btn{justify-content:center}.project-detail__nav-btn{width:36px;height:36px}.project-detail__nav-btn--prev{left:.5rem}.project-detail__nav-btn--next{right:.5rem}}@media (min-width: 768px){.project-detail{flex-direction:row;gap:2.5rem}.project-detail__gallery{flex:1;max-width:400px}.project-detail__content{flex:1}.project-detail__main-image{height:250px}}@media (prefers-color-scheme: dark){.project-detail__title{color:#f9fafb}.project-detail__category{background:#374151;color:#d1d5db}.project-detail__description h4,.project-detail__technologies h4{color:#f3f4f6}.project-detail__description p{color:#d1d5db}.project-detail__tech-tag{background:#1e3a8a;color:#bfdbfe;border-color:#1e40af}.project-detail__action-btn--secondary{background:#374151;color:#f3f4f6;border-color:#4b5563}.project-detail__action-btn--secondary:hover{background:#4b5563;border-color:#6b7280}.project-detail__image-placeholder{color:#6b7280}}.about-section{padding:120px 0;background:linear-gradient(135deg,#f8fafc,#e2e8f0);position:relative;overflow:hidden}.about-section:before{content:"";position:absolute;inset:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grain" width="100" height="100" patternUnits="userSpaceOnUse"><circle cx="50" cy="50" r="0.5" fill="%23000" opacity="0.02"/></pattern></defs><rect width="100" height="100" fill="url(%23grain)"/></svg>');pointer-events:none}.about-container{max-width:1200px;margin:0 auto;padding:0 2rem;position:relative;z-index:1}.about-content{display:grid;grid-template-columns:2fr 1fr;gap:4rem;align-items:start;margin-bottom:5rem}.about-text{padding-right:2rem}.about-title{font-size:3rem;font-weight:700;color:#1e293b;margin-bottom:2rem;position:relative;line-height:1.2}.about-title:after{content:"";position:absolute;bottom:-.5rem;left:0;width:60px;height:4px;background:linear-gradient(90deg,#3b82f6,#06b6d4);border-radius:2px}.about-summary{font-size:1.125rem;line-height:1.8;color:#475569}.about-summary p{margin-bottom:1.5rem}.about-summary p:last-child{margin-bottom:0}.about-photo{display:flex;justify-content:center;align-items:flex-start}.photo-container{position:relative;width:280px;height:350px;border-radius:20px;overflow:hidden;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;transition:transform .3s ease,box-shadow .3s ease}.photo-container:hover{transform:translateY(-8px);box-shadow:0 25px 50px -12px #00000040,0 20px 25px -5px #0000001a}.profile-image{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.photo-container:hover .profile-image{transform:scale(1.05)}.photo-overlay{position:absolute;inset:0;background:linear-gradient(135deg,#3b82f61a,#06b6d41a);opacity:0;transition:opacity .3s ease}.photo-container:hover .photo-overlay{opacity:1}.skills-section{margin-top:3rem}.skills-title{font-size:2.25rem;font-weight:600;color:#1e293b;text-align:center;margin-bottom:3rem;position:relative}.skills-title:after{content:"";position:absolute;bottom:-.75rem;left:50%;transform:translate(-50%);width:80px;height:3px;background:linear-gradient(90deg,#3b82f6,#06b6d4);border-radius:2px}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}.skill-category{background:#fff;padding:2rem;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transition:transform .2s ease,box-shadow .2s ease;border:1px solid #e2e8f0}.skill-category:hover{transform:translateY(-4px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.category-title{font-size:1.25rem;font-weight:600;color:#1e293b;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:2px solid #e2e8f0}.skills-list{display:flex;flex-wrap:wrap;gap:.75rem}.skill-tag{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:25px;font-size:.875rem;font-weight:500;transition:all .2s ease;cursor:default;border:2px solid transparent}.skill-tag:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.skill-advanced{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-color:#059669}.skill-intermediate{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border-color:#2563eb}.skill-beginner{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border-color:#d97706}.skill-name{font-weight:600}.skill-level{font-size:.75rem;opacity:.9;text-transform:capitalize;background:#fff3;padding:.125rem .5rem;border-radius:12px}@media (max-width: 1024px){.about-section{padding:80px 0}.about-content{grid-template-columns:1fr;gap:3rem;text-align:center}.about-text{padding-right:0}.photo-container{width:240px;height:300px}.skills-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}}@media (max-width: 768px){.about-section{padding:60px 0}.about-container{padding:0 1rem}.about-title{font-size:2.5rem;text-align:center}.about-summary{font-size:1rem;text-align:left}.photo-container{width:200px;height:250px}.skills-title{font-size:2rem}.skills-grid{grid-template-columns:1fr;gap:1.5rem}.skill-category{padding:1.5rem}.skill-tag{font-size:.8rem;padding:.4rem .8rem}}@media (max-width: 480px){.about-section{padding:40px 0}.about-title{font-size:2rem}.about-content{gap:2rem}.photo-container{width:180px;height:220px}.skills-title{font-size:1.75rem;margin-bottom:2rem}.skill-category{padding:1.25rem}.category-title{font-size:1.125rem}.skills-list{gap:.5rem}.skill-tag{font-size:.75rem;padding:.375rem .75rem}.skill-level{font-size:.7rem}}.app.dark .about-section{background:linear-gradient(135deg,#0f172a,#1e293b)}.app.dark .about-title,.app.dark .skills-title,.app.dark .category-title{color:#f1f5f9}.app.dark .about-summary{color:#cbd5e1}.app.dark .skill-category{background:#1e293b;border-color:#334155}.app.dark .category-title{border-bottom-color:#334155}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.about-section{animation:fadeInUp .6s ease-out}.skill-tag:focus{outline:2px solid #3b82f6;outline-offset:2px}@media (prefers-reduced-motion: reduce){.photo-container,.profile-image,.skill-tag,.skill-category{transition:none}.photo-container:hover,.skill-category:hover,.skill-tag:hover{transform:none}}.experience-section{padding:80px 0;background:linear-gradient(135deg,#f8fafc,#e2e8f0);position:relative}.experience-container{max-width:1200px;margin:0 auto;padding:0 24px}.section-header{text-align:center;margin-bottom:64px}.section-title{font-size:2.5rem;font-weight:700;color:#1e293b;margin-bottom:16px;background:linear-gradient(135deg,#3b82f6,#1e40af);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.section-subtitle{font-size:1.125rem;color:#64748b;max-width:600px;margin:0 auto;line-height:1.6}.experience-timeline{position:relative;max-width:900px;margin:0 auto}.experience-card{display:flex;margin-bottom:48px;position:relative}.timeline-marker{position:relative;margin-right:32px;display:flex;flex-direction:column;align-items:center;min-width:24px}.timeline-toggle{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#3b82f6,#1e40af);border:none;box-shadow:0 4px 12px #3b82f64d;position:relative;z-index:2;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.timeline-toggle:hover{transform:scale(1.1);box-shadow:0 6px 16px #3b82f666}.timeline-toggle:focus{outline:2px solid #3b82f6;outline-offset:2px}.triangle-icon{width:16px;height:16px;color:#fff;transition:transform .3s ease}.timeline-toggle.expanded .triangle-icon{transform:rotate(90deg)}.timeline-line{width:2px;height:100%;background:linear-gradient(180deg,#3b82f6,#e2e8f0);margin-top:16px;flex-grow:1;min-height:80px}.experience-content{flex:1;background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 20px #00000014;border:1px solid #e2e8f0;transition:all .3s ease;position:relative}.experience-content:hover{transform:translateY(-4px);box-shadow:0 8px 32px #0000001f}.experience-content:before{content:"";position:absolute;left:-8px;top:24px;width:0;height:0;border-top:8px solid transparent;border-bottom:8px solid transparent;border-right:8px solid #ffffff}.experience-header{cursor:pointer;transition:all .2s ease;border-radius:8px;padding:8px;margin:-8px}.experience-header:hover{background:#3b82f60d}.experience-title-group{margin-bottom:12px}.experience-position{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0 0 8px}.experience-company{font-size:1.25rem;font-weight:600;color:#3b82f6;margin:0}.experience-meta{display:flex;gap:24px;flex-wrap:wrap}.experience-date,.experience-location{font-size:.875rem;color:#64748b;font-weight:500;display:flex;align-items:center;gap:6px}.experience-date:before{content:"📅";font-size:.75rem}.experience-location:before{content:"📍";font-size:.75rem}.experience-details{overflow:hidden;transition:all .3s ease}.experience-details.collapsed{max-height:0;opacity:0;margin-top:0}.experience-details.expanded{max-height:1000px;opacity:1;margin-top:16px}.experience-description{margin-bottom:16px}.experience-description p{font-size:1rem;line-height:1.7;color:#475569;margin:0}.experience-achievements{margin-bottom:24px}.achievements-title{font-size:1.125rem;font-weight:600;color:#1e293b;margin:0 0 16px;display:flex;align-items:center;gap:8px}.achievements-title:before{content:"🏆";font-size:1rem}.achievements-list{list-style:none;padding:0;margin:0;display:grid;gap:12px}.achievement-item{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;background:#f1f5f9;border-radius:8px;border-left:4px solid #3b82f6;transition:all .2s ease}.achievement-item:hover{background:#e0f2fe;transform:translate(4px)}.achievement-icon{font-size:1rem;flex-shrink:0;margin-top:2px}.achievement-text{font-size:.9rem;line-height:1.5;color:#334155;font-weight:500}.experience-technologies{margin-top:24px}.technologies-title{font-size:1.125rem;font-weight:600;color:#1e293b;margin:0 0 16px;display:flex;align-items:center;gap:8px}.technologies-title:before{content:"🛠️";font-size:1rem}.technologies-list{display:flex;flex-wrap:wrap;gap:8px}.tech-tag{display:inline-block;padding:6px 12px;background:linear-gradient(135deg,#3b82f6,#1e40af);color:#fff;border-radius:20px;font-size:.8rem;font-weight:500;transition:all .2s ease;cursor:default}.tech-tag:hover{transform:translateY(-2px);box-shadow:0 4px 12px #3b82f64d}@media (max-width: 768px){.experience-section{padding:60px 0}.experience-container{padding:0 16px}.section-header{margin-bottom:48px}.section-title{font-size:2rem}.section-subtitle{font-size:1rem}.experience-card{flex-direction:column;margin-bottom:32px}.timeline-marker{flex-direction:row;margin-right:0;margin-bottom:16px;justify-content:flex-start;min-width:auto}.timeline-toggle{width:28px;height:28px;margin-right:16px}.triangle-icon{width:14px;height:14px}.timeline-line{width:100%;height:2px;margin-top:0;min-height:auto;flex-grow:1}.experience-content{padding:24px}.experience-content:before{display:none}.experience-position{font-size:1.25rem}.experience-company{font-size:1.125rem}.experience-meta{flex-direction:column;gap:8px}.achievements-list{gap:8px}.achievement-item{padding:10px 12px}.achievement-text{font-size:.85rem}.tech-tag{font-size:.75rem;padding:4px 10px}}@media (max-width: 480px){.experience-section{padding:40px 0}.section-title{font-size:1.75rem}.experience-content{padding:20px}.experience-position{font-size:1.125rem}.experience-company{font-size:1rem}.technologies-list{gap:6px}.tech-tag{font-size:.7rem;padding:4px 8px}}@media (min-width: 1200px){.experience-container{padding:0 32px}.section-title{font-size:3rem}.section-subtitle{font-size:1.25rem}.experience-content{padding:40px}}.projects{padding:6rem 0;background:linear-gradient(135deg,#f8fafc,#e2e8f0);min-height:100vh}.projects__container{max-width:1200px;margin:0 auto;padding:0 2rem}.projects__header{text-align:center;margin-bottom:3rem}.projects__title{font-size:3rem;font-weight:700;color:#1e293b;margin-bottom:1rem;background:linear-gradient(135deg,#3b82f6,#1e40af);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.projects__subtitle{font-size:1.25rem;color:#64748b;max-width:600px;margin:0 auto;line-height:1.6}.projects__filters{display:flex;justify-content:center;gap:1rem;margin-bottom:3rem;flex-wrap:wrap}.projects__filter{padding:.75rem 1.5rem;border:2px solid #e2e8f0;background:#fff;color:#64748b;border-radius:2rem;font-weight:500;cursor:pointer;transition:all .3s ease;text-transform:capitalize}.projects__filter:hover{border-color:#3b82f6;color:#3b82f6;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f626}.projects__filter.active{background:#3b82f6;border-color:#3b82f6;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f64d}.projects__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem;margin-bottom:2rem}.projects__card{background:#fff;border-radius:1rem;overflow:hidden;box-shadow:0 4px 6px #0000000d;transition:all .3s ease;cursor:pointer;position:relative}.projects__card:hover{transform:translateY(-8px);box-shadow:0 20px 40px #0000001a}.projects__card.featured{border:2px solid #3b82f6;position:relative}.projects__card.featured:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#3b82f6,#1e40af);z-index:1}.projects__card-image{position:relative;height:200px;overflow:hidden}.projects__card-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.projects__card:hover .projects__card-image img{transform:scale(1.05)}.projects__card-actions{display:flex;gap:.75rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid #f1f5f9}.projects__action-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:.5rem;font-weight:500;font-size:.875rem;cursor:pointer;transition:all .3s ease;text-decoration:none;flex:1;justify-content:center}.projects__action-btn svg{width:16px;height:16px}.projects__card-content{padding:1.5rem}.projects__card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1rem;gap:1rem}.projects__card-title{font-size:1.25rem;font-weight:600;color:#1e293b;margin:0;line-height:1.4}.projects__featured-badge{background:linear-gradient(135deg,#3b82f6,#1e40af);color:#fff;padding:.25rem .75rem;border-radius:1rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;flex-shrink:0}.projects__card-description{color:#64748b;line-height:1.6;margin-bottom:1.5rem;font-size:.95rem}.projects__card-technologies{display:flex;flex-wrap:wrap;gap:.5rem}.projects__tech-tag{background:#f1f5f9;color:#475569;padding:.375rem .75rem;border-radius:.5rem;font-size:.8rem;font-weight:500;transition:all .3s ease}.projects__card:hover .projects__tech-tag{background:#e0f2fe;color:#0369a1}.projects__empty{text-align:center;padding:3rem;color:#64748b;font-size:1.1rem}@media (max-width: 1024px){.projects__grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.projects__title{font-size:2.5rem}}@media (max-width: 768px){.projects{padding:4rem 0}.projects__container{padding:0 1rem}.projects__title{font-size:2rem}.projects__subtitle{font-size:1.1rem}.projects__grid{grid-template-columns:1fr;gap:1.5rem}.projects__filters{gap:.5rem}.projects__filter{padding:.5rem 1rem;font-size:.9rem}.projects__card-image{height:180px}.projects__card-content{padding:1.25rem}.projects__card-header{flex-direction:column;align-items:flex-start;gap:.5rem}.projects__action-btn{padding:.5rem 1rem;font-size:.9rem}}@media (max-width: 480px){.projects__container{padding:0 .75rem}.projects__title{font-size:1.75rem}.projects__card-actions{flex-direction:column;gap:.5rem}.projects__action-btn{justify-content:center}.projects__filters{justify-content:flex-start;overflow-x:auto;padding-bottom:.5rem}.projects__filter{flex-shrink:0}}.app.dark .projects{background:linear-gradient(135deg,#0f172a,#1e293b)}.app.dark .projects__title{color:#f8fafc}.app.dark .projects__subtitle{color:#94a3b8}.app.dark .projects__filter{background:#1e293b;border-color:#334155;color:#94a3b8}.app.dark .projects__filter:hover{border-color:#3b82f6;color:#3b82f6}.app.dark .projects__card{background:#1e293b;box-shadow:0 4px 6px #0000004d}.app.dark .projects__card:hover{box-shadow:0 20px 40px #0006}.app.dark .projects__card-title{color:#f8fafc}.app.dark .projects__card-description{color:#94a3b8}.app.dark .projects__tech-tag{background:#334155;color:#cbd5e1}.app.dark .projects__card:hover .projects__tech-tag{background:#1e40af;color:#dbeafe}.app.dark .projects__card-actions{border-top-color:#334155}.app.dark .projects__action-btn{color:#cbd5e1}.contact{padding:80px 0;background:linear-gradient(135deg,#f8fafc,#e2e8f0);min-height:100vh;display:flex;align-items:center}.contact-container{max-width:1200px;margin:0 auto;padding:0 20px;width:100%}.contact-header{text-align:center;margin-bottom:60px}.contact-header h2{font-size:2.5rem;font-weight:700;color:#1e293b;margin-bottom:16px}.contact-header p{font-size:1.125rem;color:#64748b;max-width:600px;margin:0 auto;line-height:1.6}.contact-content{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}.contact-info h3,.contact-form h3{font-size:1.5rem;font-weight:600;color:#1e293b;margin-bottom:24px}.contact-details{margin-bottom:40px}.contact-item{display:flex;align-items:flex-start;gap:16px;margin-bottom:24px}.contact-icon{font-size:1.5rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#3b82f6;border-radius:50%;flex-shrink:0}.contact-item h4{font-size:1rem;font-weight:600;color:#1e293b;margin-bottom:4px}.contact-item p,.contact-item a{color:#64748b;text-decoration:none;transition:color .2s ease}.contact-item a:hover{color:#3b82f6}.social-links h4{font-size:1rem;font-weight:600;color:#1e293b;margin-bottom:16px}.social-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.social-link{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fff;border-radius:8px;text-decoration:none;color:#64748b;transition:all .2s ease;border:1px solid #e2e8f0}.social-link:hover{background:#3b82f6;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f64d}.social-icon{font-size:1.25rem}.social-name{font-weight:500}.contact-form-wrapper{background:#fff;padding:40px;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a}.form-group{margin-bottom:24px}.form-group label{display:block;font-weight:500;color:#374151;margin-bottom:8px;font-size:.875rem}.form-group input,.form-group textarea{width:100%;padding:12px 16px;border:1px solid #d1d5db;border-radius:8px;font-size:1rem;transition:all .2s ease;background:#fff}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group input.error,.form-group textarea.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.error-message{display:block;color:#ef4444;font-size:.875rem;margin-top:4px}.form-group textarea{resize:vertical;min-height:120px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 24px;border:none;border-radius:8px;font-size:1rem;font-weight:500;text-decoration:none;cursor:pointer;transition:all .2s ease;min-width:140px}.btn-primary{background:#3b82f6;color:#fff}.btn-primary:hover:not(:disabled){background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.contact-success{text-align:center;padding:60px 40px;background:#fff;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;max-width:500px;margin:0 auto}.success-icon{font-size:4rem;margin-bottom:24px}.contact-success h2{font-size:2rem;font-weight:700;color:#1e293b;margin-bottom:16px}.contact-success p{font-size:1.125rem;color:#64748b;margin-bottom:32px;line-height:1.6}.app.dark .contact{background:linear-gradient(135deg,#0f172a,#1e293b)}.app.dark .contact-header h2,.app.dark .contact-info h3,.app.dark .contact-form h3,.app.dark .contact-item h4,.app.dark .social-links h4{color:#f1f5f9}.app.dark .contact-header p,.app.dark .contact-item p,.app.dark .contact-item a{color:#94a3b8}.app.dark .contact-form-wrapper,.app.dark .social-link,.app.dark .contact-success{background:#1e293b;border-color:#334155}.app.dark .form-group input,.app.dark .form-group textarea{background:#0f172a;border-color:#334155;color:#f1f5f9}.app.dark .form-group label{color:#e2e8f0}.app.dark .social-link{color:#94a3b8}.app.dark .contact-success h2{color:#f1f5f9}.app.dark .contact-success p{color:#94a3b8}@media (max-width: 1024px){.contact-content{grid-template-columns:1fr;gap:40px}.contact-form-wrapper{padding:32px}}@media (max-width: 768px){.contact{padding:60px 0}.contact-container{padding:0 16px}.contact-header{margin-bottom:40px}.contact-header h2{font-size:2rem}.contact-header p{font-size:1rem}.contact-content{gap:32px}.contact-form-wrapper{padding:24px}.social-grid{grid-template-columns:1fr}.contact-success{padding:40px 24px}.contact-success h2{font-size:1.5rem}.success-icon{font-size:3rem}}@media (max-width: 480px){.contact-header h2{font-size:1.75rem}.contact-form-wrapper{padding:20px}.form-group input,.form-group textarea{padding:10px 12px}.btn{padding:10px 20px;font-size:.875rem}}
