*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#fafafa;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;transition:background-color .3s;overflow-x:hidden}.dark body{background:#0f0f0f}html{scroll-behavior:smooth}.portfolio{color:#0f172a;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f8fafc;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}body.menu-open{overflow:hidden}.navbar{-webkit-backdrop-filter:blur(20px)saturate(180%);z-index:1000;background:#fffffffa;border-bottom:1px solid #e5e7eb;width:100%;padding:1.25rem 0;transition:all .3s;position:fixed;top:0;box-shadow:0 2px 8px #0000000f,0 1px 2px #0000000a}.portfolio.dark-mode .navbar{border-bottom:1px solid #2a2a2a}.nav-container{justify-content:space-between;align-items:center;width:100%;max-width:1200px;margin:0 auto;padding:0 2rem;display:flex}.nav-right{align-items:center;gap:1.5rem;display:flex}.logo{letter-spacing:-.5px;color:#0f172a;background:linear-gradient(135deg,#14b8a6 0%,#0d9488 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.35rem;font-weight:800;text-decoration:none;transition:all .3s}.logo[style*=pointer]{cursor:pointer}.logo:hover{background:linear-gradient(135deg,#0d9488 0%,#14b8a6 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;transform:translate(-2px)}button.logo{cursor:pointer;font:inherit;background:0 0;border:none;padding:0}.nav-menu{gap:2.5rem;margin:0;padding:0;list-style:none;display:flex}.nav-menu a{color:#475569;letter-spacing:-.2px;outline:none;font-size:.95rem;font-weight:600;transition:all .25s;position:relative;border-bottom:none!important;text-decoration:none!important}.nav-menu a:hover{color:#14b8a6}.nav-menu a:after{content:"";opacity:0;pointer-events:none;background:#14b8a6;width:0;height:2px;transition:width .3s,opacity .3s;position:absolute;bottom:-5px;left:0}.nav-menu a:hover:after{opacity:1;width:100%}.mobile-menu-toggle{cursor:pointer;z-index:1001;background:0 0;border:none;padding:.5rem;display:none}.hamburger{flex-direction:column;justify-content:space-between;width:24px;height:18px;transition:all .3s;display:flex}.hamburger span{background:#1a1a1a;border-radius:2px;width:100%;height:2px;transition:all .3s;display:block}.hamburger.open span:first-child{transform:rotate(45deg)translate(8px,8px)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:rotate(-45deg)translate(7px,-7px)}.theme-toggle{cursor:pointer;background:0 0;border:1.5px solid #e5e5e5;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;padding:0;font-size:1.2rem;transition:all .2s;display:flex;position:relative}.theme-toggle:hover{background:#f3f4f6;border-color:#14b8a6;transform:translateY(-2px);box-shadow:0 2px 8px #14b8a626}.theme-toggle:active{transform:translateY(0)}.theme-toggle-desktop{display:flex}.theme-toggle-mobile{display:none}.mobile-menu-header{border-bottom:1px solid #f0f0f0;justify-content:flex-end;align-items:center;padding:1rem 2rem;display:none;position:relative}.container{max-width:1200px;margin:0 auto;padding:0 2rem}.hero{background:linear-gradient(135deg,#f0fdfa 0%,#fff 30%,#f0fdfa 60%,#fff 100%);justify-content:center;align-items:center;min-height:100vh;padding:9rem 2rem 5rem;display:flex;position:relative;overflow:hidden}.hero:before{content:"";pointer-events:none;background:radial-gradient(circle at 20% 30%,#14b8a614 0%,#0000 40%),radial-gradient(circle at 80% 70%,#14b8a60f 0%,#0000 40%),radial-gradient(circle,#14b8a608 0%,#0000 60%);animation:15s infinite gradientShift;position:absolute;inset:0}@keyframes gradientShift{0%,to{opacity:1}50%{opacity:.8}}.hero-content{grid-template-columns:1fr 1.2fr;align-items:center;gap:5rem;width:100%;max-width:1200px;display:grid}.hero-image{justify-content:center;align-items:center;display:flex}.image-placeholder{background:linear-gradient(135deg,#f8f9fa 0%,#fff 100%);border:3px solid #14b8a61a;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:320px;height:320px;transition:all .3s;display:flex;position:relative;overflow:hidden;box-shadow:0 8px 32px #00000014,0 2px 8px #14b8a61a}.image-placeholder:before{content:"";-webkit-mask-composite:xor;opacity:0;background:linear-gradient(135deg,#14b8a633,#14b8a60d);border-radius:50%;padding:3px;transition:opacity .3s;position:absolute;inset:-3px;-webkit-mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);-webkit-mask-position:0 0,0 0;mask-position:0 0,0 0;-webkit-mask-size:auto,auto;mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.image-placeholder:hover:before{opacity:1}.profile-img{object-fit:cover;border-radius:50%;width:100%;height:100%;display:block}.image-placeholder span{opacity:.5;margin-bottom:1rem;font-size:4rem}.image-placeholder p{text-align:center;color:#6b7280;padding:0 1.5rem;font-size:.85rem;line-height:1.5}.hero-text{text-align:left;animation:.8s ease-out fadeInUp}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.hero-name{color:#0f172a;letter-spacing:-1.5px;background:linear-gradient(135deg,#0f172a 0%,#14b8a6 100%);-webkit-text-fill-color:transparent;text-shadow:0 2px 4px #0f172a1a;-webkit-background-clip:text;background-clip:text;margin-bottom:1rem;font-size:2.8rem;font-weight:800;line-height:1.1}.typewriter-cursor{color:#14b8a6;margin-left:2px;font-weight:400;animation:1s infinite blink;display:inline-block}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.portfolio.dark-mode .typewriter-cursor{color:#14b8a6}.hero-title{color:#475569;letter-spacing:-.3px;margin-bottom:1.5rem;font-size:1.5rem;font-weight:600}.hero-description{color:#475569;max-width:520px;margin-bottom:2.5rem;font-size:1.125rem;font-weight:400;line-height:1.75}.hero-buttons{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.btn{cursor:pointer;box-sizing:border-box;white-space:nowrap;letter-spacing:-.2px;border:none;border-radius:10px;justify-content:center;align-items:center;min-height:44px;padding:.875rem 1.75rem;font-size:.95rem;font-weight:600;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex;position:relative;overflow:hidden}.btn-primary{color:#fff;background:linear-gradient(135deg,#14b8a6 0%,#0d9488 100%);box-shadow:0 4px 14px #14b8a640,0 2px 4px #0000001a}.btn-primary:hover{background:linear-gradient(135deg,#0d9488 0%,#0f766e 100%);transform:translateY(-3px);box-shadow:0 8px 20px #14b8a659,0 4px 8px #00000026}.btn-primary:active{transform:translateY(-1px)}.btn-secondary{color:#14b8a6;background:0 0;border:2px solid #14b8a6;box-shadow:0 2px 8px #14b8a61a,0 1px 2px #0000000d}.btn-secondary:hover{color:#0d9488;background:linear-gradient(135deg,#f0fdfa 0%,#ccfbf1 100%);border-color:#0d9488;transform:translateY(-3px);box-shadow:0 6px 16px #14b8a633}.btn-secondary:active{transform:translateY(-1px)}.btn-outline{color:#0f172a;background:0 0;border:2px solid #e5e7eb;justify-content:center;align-items:center;gap:.5rem;display:flex;box-shadow:0 1px 3px #0000000d}.btn-outline:hover{color:#fff;background:#0f172a;border-color:#0f172a;transform:translateY(-2px);box-shadow:0 4px 12px #0f172a26,0 2px 4px #0000001a}.btn-icon{width:18px;height:18px}.portfolio.dark-mode .btn-primary{background:linear-gradient(135deg,#64748b 0%,#475569 100%);box-shadow:0 4px 14px #64748b40,0 2px 4px #0003}.portfolio.dark-mode .btn-primary:hover{background:linear-gradient(135deg,#475569 0%,#334155 100%);box-shadow:0 8px 20px #64748b59,0 4px 8px #00000040}.portfolio.dark-mode .btn-outline{color:#fff;border-color:#94a3b8}.portfolio.dark-mode .btn-outline:hover{color:#0f172a;background:#94a3b8;border-color:#94a3b8}.btn-text{color:#6b7280;box-shadow:none;text-underline-offset:4px;background:0 0;border:none;padding:.875rem 1rem;-webkit-text-decoration:underline #6b72804d;text-decoration:underline #6b72804d;text-decoration-thickness:1.5px}.btn-text:hover{color:#14b8a6;box-shadow:none;background:0 0;text-decoration-color:#14b8a6;transform:translateY(-1px)}.portfolio.dark-mode .btn-text{color:#9ca3af;text-decoration-color:#9ca3af4d}.portfolio.dark-mode .btn-text:hover{color:#94a3b8;text-decoration-color:#94a3b8}.hero-stats{border-top:1px solid #e5e5e580;gap:2.5rem;margin-top:2.5rem;margin-bottom:2rem;padding-top:2rem;display:flex}.stat-item{flex-direction:column;gap:.25rem;display:flex}.stat-number{color:#14b8a6;background:linear-gradient(135deg,#14b8a6 0%,#0d9488 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:2rem;font-weight:800;line-height:1}.stat-label{color:#475569;text-transform:uppercase;letter-spacing:.5px;font-size:.875rem;font-weight:500}.hero-tech-stack{flex-wrap:wrap;gap:.75rem;margin-top:1.5rem;display:flex}.tech-badge{color:#0d9488;background:#14b8a61a;border:1px solid #14b8a633;border-radius:20px;align-items:center;padding:.5rem 1rem;font-size:.85rem;font-weight:600;transition:all .2s;display:inline-flex}.tech-badge:hover{background:#14b8a626;border-color:#14b8a64d;transform:translateY(-2px);box-shadow:0 4px 8px #14b8a626}.portfolio.dark-mode .stat-number{background:linear-gradient(135deg,#94a3b8 0%,#64748b 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.portfolio.dark-mode .stat-label{color:#9ca3af}.portfolio.dark-mode .tech-badge{color:#94a3b8;background:#94a3b81a;border-color:#94a3b833}.portfolio.dark-mode .tech-badge:hover{background:#94a3b826;border-color:#94a3b84d;box-shadow:0 4px 8px #94a3b826}section{padding:7rem 0;scroll-margin-top:67px;position:relative}section:before{content:"";background:linear-gradient(90deg,#0000,#e5e5e5cc,#0000);height:1px;position:absolute;top:0;left:0;right:0}.section-title{text-align:center;color:#0f172a;letter-spacing:-1.2px;width:100%;margin-bottom:4.5rem;font-size:2.875rem;font-weight:800;line-height:1.2;display:inline-block;position:relative}.section-title:after{content:"";background:linear-gradient(135deg,#14b8a6 0%,#0d9488 100%);border-radius:2px;width:60px;height:4px;position:absolute;bottom:-1rem;left:50%;transform:translate(-50%)}.portfolio.dark-mode .section-title:after{background:linear-gradient(135deg,#94a3b8 0%,#64748b 100%)}.about{background:#fff;box-shadow:0 1px 3px #0000000d}.about-content{max-width:800px;margin:0 auto}.about-text p{color:#475569;margin-bottom:1.75rem;font-size:1.15rem;font-weight:400;line-height:1.85}.projects{background:#f1f5f9}.project-search-container{max-width:600px;margin-bottom:2rem;margin-left:auto;margin-right:auto}.project-search{color:#1a1a1a;background:#fff;border:1.5px solid #e5e5e5cc;border-radius:12px;width:100%;padding:1rem 1.5rem;font-size:.95rem;font-weight:500;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 6px #0000000a}.project-search:focus{border-color:#14b8a6;outline:none;transform:translateY(-1px);box-shadow:0 0 0 4px #14b8a61f,0 4px 12px #14b8a61a}.project-search::placeholder{color:#9ca3af}.portfolio.dark-mode .project-search{color:#fff;background:#1a1a1a;border-color:#2a2a2a}.portfolio.dark-mode .project-search:focus{border-color:#94a3b8;box-shadow:0 0 0 4px #94a3b81f,0 4px 12px #94a3b81a}.portfolio.dark-mode .project-search::placeholder{color:#6b7280}.project-filters{flex-wrap:wrap;justify-content:center;gap:1rem;margin-bottom:3rem;display:flex}.filter-btn{color:#475569;cursor:pointer;letter-spacing:-.2px;background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:.75rem 1.75rem;font-size:.95rem;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 2px 4px #0000000a,0 1px 2px #00000005}.filter-btn:hover{color:#14b8a6;background:#f0fdfa;border-color:#14b8a6}.filter-btn.active{color:#fff;background:linear-gradient(135deg,#14b8a6 0%,#0d9488 100%);border-color:#14b8a6;transform:translateY(-1px);box-shadow:0 4px 12px #14b8a64d}.filter-btn.active:hover{background:linear-gradient(135deg,#0d9488 0%,#0f766e 100%);border-color:#0d9488;transform:translateY(-2px);box-shadow:0 6px 16px #14b8a659}.projects-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;display:grid}.project-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;flex-direction:column;align-self:start;transition:transform .4s cubic-bezier(.4,0,.2,1),box-shadow .4s cubic-bezier(.4,0,.2,1),border-color .4s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden;box-shadow:0 2px 8px #0000000f,0 1px 2px #0000000a}.project-card.has-screenshots{position:relative}.project-card:before{content:"";opacity:0;background:linear-gradient(90deg,#14b8a6,#0d9488);height:3px;transition:opacity .3s;position:absolute;top:0;left:0;right:0}.project-card:hover{border-width:1.5px;border-color:#14b8a6;transform:translateY(-10px);box-shadow:0 12px 32px #0000001f,0 4px 16px #14b8a626,0 2px 4px #00000014}.project-card:hover:before{opacity:1}.project-image{background:#f3f4f6;justify-content:center;align-items:center;width:100%;height:180px;padding:1.5rem;display:flex;position:relative;overflow:hidden}.project-img{object-fit:contain;width:auto;max-width:100%;height:auto;max-height:100%;transition:transform .3s;display:block}.project-card:hover .project-img{transform:scale(1.05)}.image-placeholder-small{opacity:.3;color:#9ca3af;justify-content:center;align-items:center;width:100%;height:100%;font-size:3rem;display:flex}.project-info{flex-direction:column;flex:1;padding:1.5rem;display:flex}.project-info h3{color:#0f172a;letter-spacing:-.3px;margin-bottom:.75rem;font-size:1.25rem;font-weight:700;line-height:1.3}.project-date{color:#64748b;align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.9rem;font-weight:500;display:flex}.project-date svg{color:#14b8a6;flex-shrink:0;width:16px;height:16px}.portfolio.dark-mode .project-date{color:#94a3b8}.portfolio.dark-mode .project-date svg{color:#14b8a6}.project-description-wrapper{flex-direction:column;min-height:4.5em;margin-bottom:1rem;display:flex}.project-info p{color:#475569;word-wrap:break-word;overflow-wrap:break-word;-webkit-line-clamp:3;line-clamp:3;box-orient:vertical;-webkit-box-orient:vertical;flex:none;margin-bottom:0;font-size:.9rem;line-height:1.6;display:-webkit-box;overflow:hidden}.project-tags{flex-wrap:wrap;gap:.5rem;margin-top:auto;margin-bottom:1rem;display:flex}.project-tags span{color:#4b5563;background:linear-gradient(135deg,#f8f9fa 0%,#f3f4f6 100%);border:1px solid #e5e5e5cc;border-radius:7px;padding:.5rem .9rem;font-size:.8rem;font-weight:600;transition:all .2s;box-shadow:0 1px 2px #0000000a}.project-tags span:hover{color:#14b8a6;background:linear-gradient(135deg,#f0fdfa 0%,#ccfbf1 100%);border-color:#14b8a6;transform:translateY(-1px)}.project-tag-hidden-desktop{display:none}.project-tag-more-desktop{display:inline-block}.project-collaborators{border-top:1px solid #e5e7eb;margin:1rem 0;padding-top:1rem}.collaborators-label{color:#64748b;margin-bottom:.75rem;font-size:.85rem;font-weight:600;display:block}.collaborators-list{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.collaborator-item{cursor:pointer;border:2px solid #e5e7eb;border-radius:50%;width:40px;height:40px;transition:all .2s;position:relative;overflow:hidden}.collaborator-item:hover{border-color:#14b8a6;transform:scale(1.1);box-shadow:0 2px 8px #14b8a64d}.collaborator-image{object-fit:cover;width:100%;height:100%;display:block}.portfolio.dark-mode .project-collaborators{border-top-color:#2a2a2a}.portfolio.dark-mode .collaborators-label{color:#94a3b8}.portfolio.dark-mode .collaborator-item{border-color:#3a3a3a}.portfolio.dark-mode .collaborator-item:hover{border-color:#14b8a6}.project-client{border-top:1px solid #e5e7eb;margin:1rem 0;padding-top:1rem}.client-label{color:#64748b;margin-bottom:.75rem;font-size:.85rem;font-weight:600;display:block}.client-info{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.client-item{cursor:pointer;background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;align-items:center;gap:.75rem;padding:.5rem .75rem;transition:all .2s;display:flex}.client-item:hover{background:#f0fdfa;border-color:#14b8a6;transform:translateY(-1px);box-shadow:0 2px 8px #14b8a633}.client-image{object-fit:cover;object-position:center center;border:2px solid #e5e7eb;border-radius:50%;flex-shrink:0;width:48px;height:48px;display:block}.client-name{color:#0f172a;font-size:.9rem;font-weight:500}.portfolio.dark-mode .project-client{border-top-color:#2a2a2a}.portfolio.dark-mode .client-label{color:#94a3b8}.portfolio.dark-mode .client-item{background:#1a1a1a;border-color:#3a3a3a}.portfolio.dark-mode .client-item:hover{background:#1a2e2a;border-color:#14b8a6}.portfolio.dark-mode .client-image{border-color:#3a3a3a}.portfolio.dark-mode .client-name{color:#f1f5f9}.image-modal-overlay{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10000;background:#000000e6;justify-content:center;align-items:center;width:100%;height:100%;animation:.2s fadeIn;display:flex;position:fixed;top:0;left:0}.image-modal-content{flex-direction:column;justify-content:center;align-items:center;gap:1rem;max-width:95vw;max-height:95vh;padding:0 4rem;display:flex;position:relative}.image-modal-close{cursor:pointer;color:#fff;z-index:10001;background:#ffffff1a;border:2px solid #ffffff4d;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:all .2s;display:flex;position:absolute;top:-3rem;right:0}.image-modal-close:hover{background:#fff3;border-color:#ffffff80;transform:scale(1.1)}.image-modal-close svg{width:20px;height:20px}.enlarged-image{object-fit:contain;object-position:center center;border-radius:12px;width:auto;max-width:95%;height:auto;max-height:90vh;animation:.3s zoomIn;box-shadow:0 20px 60px #00000080}.image-modal-nav{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;color:#fff;z-index:10002;background:#ffffff1a;border:2px solid #ffffff4d;border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;transition:all .2s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.image-modal-nav:hover{background:#fff3;border-color:#ffffff80;transform:translateY(-50%)scale(1.1)}.image-modal-nav svg{width:24px;height:24px}.image-modal-prev{left:0}.image-modal-next{right:0}.enlarged-image-name{color:#fff;text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:8px;margin:0;padding:.5rem 1rem;font-size:1.2rem;font-weight:600}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes zoomIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@media (max-width:768px){.image-modal-content{max-width:95vw;max-height:95vh;padding:1rem 3rem}.image-modal-close{width:36px;height:36px;top:-2.5rem;right:.5rem}.image-modal-close svg{width:18px;height:18px}.enlarged-image{max-height:75vh}.enlarged-image-name{padding:.4rem .8rem;font-size:1rem}.enlarged-image{max-width:98%;max-height:85vh}.image-modal-nav{width:40px;height:40px}.image-modal-nav svg{width:20px;height:20px}.image-modal-prev{left:0}.image-modal-next{right:0}}.project-modal-overlay{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10000;scrollbar-width:none;-ms-overflow-style:none;background:#000000d9;justify-content:center;align-items:center;width:100%;height:100%;padding:2rem;animation:.3s fadeIn;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.project-modal-overlay::-webkit-scrollbar{display:none}.portfolio:not(.dark-mode) .project-modal-overlay{background:#000000bf}.project-modal-content{scrollbar-width:none;-ms-overflow-style:none;background:#1a1a1a;border-radius:16px;flex-direction:column;width:1200px;max-width:95%;height:700px;animation:.3s slideUp;display:flex;position:relative;overflow:hidden;box-shadow:0 20px 60px #00000080}.project-modal-content::-webkit-scrollbar{display:none}.portfolio.dark-mode .project-modal-content{background:#1a1a1a}.portfolio:not(.dark-mode) .project-modal-content{background:#fff;border:1px solid #e5e7eb;box-shadow:0 20px 60px #00000026}.portfolio:not(.dark-mode) .project-modal-details,.portfolio:not(.dark-mode) .project-modal-title{color:#0f172a}.portfolio:not(.dark-mode) .project-modal-description{color:#475569}.portfolio:not(.dark-mode) .project-modal-technologies-title,.portfolio:not(.dark-mode) .project-modal-section-title,.portfolio:not(.dark-mode) .project-modal-close{color:#0f172a}.portfolio:not(.dark-mode) .project-modal-close:hover{background:#0000000d}.portfolio:not(.dark-mode) .project-modal-logo{background:#00000008;border-color:#e5e7eb}.portfolio:not(.dark-mode) .project-modal-main-screenshot{background:#f8fafc;border-color:#e5e7eb}.portfolio:not(.dark-mode) .project-modal-collaborator-item,.portfolio:not(.dark-mode) .project-modal-client-item{background:#00000008;border-color:#e5e7eb}.portfolio:not(.dark-mode) .project-modal-collaborator-item:hover,.portfolio:not(.dark-mode) .project-modal-client-item:hover{background:#0000000d;border-color:#cbd5e1}.portfolio:not(.dark-mode) .project-modal-collaborator-name,.portfolio:not(.dark-mode) .project-modal-client-name{color:#0f172a}.portfolio:not(.dark-mode) .project-modal-btn-secondary{color:#0f172a;border-color:#0f172a}.portfolio:not(.dark-mode) .project-modal-btn-secondary:hover{background:#0000000d}.project-modal-close{color:#fff;cursor:pointer;z-index:10001;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:40px;height:40px;font-size:2rem;transition:all .2s;display:flex;position:absolute;top:1.5rem;right:1.5rem}.project-modal-close:hover{background:#ffffff1a;transform:scale(1.1)}.project-modal-close svg{width:24px;height:24px}.project-modal-body{flex:1;grid-template-columns:1fr 1fr;gap:2rem;height:100%;padding:2rem;display:grid;overflow:hidden}.project-modal-screenshots{flex-direction:column;gap:1.5rem;display:flex}.project-modal-logo{aspect-ratio:1;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:100%;min-height:250px;max-height:250px;padding:1.5rem;display:flex}.project-modal-logo-image{object-fit:contain;width:auto;max-width:100%;height:auto;max-height:100%;display:block}.project-modal-thumbnails{grid-template-columns:repeat(6,1fr);gap:.75rem;margin-top:1rem;display:grid}.project-modal-main-image{object-fit:contain;width:100%;height:auto;display:block}.project-modal-thumbnail{aspect-ratio:9/16;cursor:pointer;opacity:.7;background:#0f0f0f;border:2px solid #0000;border-radius:8px;width:100%;transition:all .2s;overflow:hidden}.project-modal-thumbnail:hover{opacity:1;border-color:#ffffff4d;transform:scale(1.05)}.project-modal-thumbnail.active{opacity:1;border-width:2px;border-color:#14b8a6}.portfolio:not(.dark-mode) .project-modal-thumbnail{background:#f8fafc}.portfolio:not(.dark-mode) .project-modal-thumbnail:hover{border-color:#14b8a6}.project-modal-thumbnail-image{object-fit:cover;width:100%;height:100%;display:block}.project-modal-details{color:#fff;flex-direction:column;justify-content:space-between;gap:.75rem;max-height:100%;display:flex;overflow:hidden}.project-modal-category{color:#fff;background:linear-gradient(135deg,#14b8a6 0%,#0d9488 100%);border-radius:20px;width:fit-content;padding:.5rem 1rem;font-size:.85rem;font-weight:600;display:inline-block}.portfolio.dark-mode .project-modal-category{color:#fff;background:linear-gradient(135deg,#14b8a6 0%,#0d9488 100%);border:none}.portfolio:not(.dark-mode) .project-modal-category{color:#fff;background:linear-gradient(135deg,#14b8a6 0%,#0d9488 100%)}.project-modal-title{color:#fff;margin:0;font-size:1.5rem;font-weight:700;line-height:1.2}.project-modal-date{color:#94a3b8;align-items:center;gap:.5rem;margin:.5rem 0;font-size:.9rem;font-weight:500;display:flex}.project-modal-date svg{color:#94a3b8;flex-shrink:0;width:16px;height:16px}.portfolio.dark-mode .project-modal-date,.portfolio.dark-mode .project-modal-date svg{color:#94a3b8}.portfolio:not(.dark-mode) .project-modal-date,.portfolio:not(.dark-mode) .project-modal-date svg{color:#64748b}.project-modal-description{color:#d1d5db;margin:0;font-size:.9rem;line-height:1.4}.project-modal-technologies{flex-direction:column;gap:.5rem;display:flex}.project-modal-technologies-title,.project-modal-section-title{color:#fff;text-transform:uppercase;letter-spacing:1px;margin:0 0 .5rem;font-size:.8rem;font-weight:600}.project-modal-tags{flex-wrap:wrap;gap:.5rem;display:flex}.project-modal-tag{color:#fff;background:linear-gradient(135deg,#14b8a6 0%,#0d9488 100%);border-radius:20px;padding:.35rem .75rem;font-size:.75rem;font-weight:600}.portfolio.dark-mode .project-modal-tag{color:#d1d5db;background:#2a2a2a;border:1px solid #3a3a3a}.portfolio:not(.dark-mode) .project-modal-tag{color:#fff;background:linear-gradient(135deg,#14b8a6 0%,#0d9488 100%)}.project-modal-collaborators,.project-modal-clients{flex-direction:column;gap:.5rem;display:flex}.project-modal-collaborators-list,.project-modal-clients-list{flex-wrap:wrap;gap:.5rem;display:flex}.project-modal-collaborator-item,.project-modal-client-item{cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:10px;align-items:center;gap:.5rem;padding:.5rem;transition:all .2s;display:flex}.project-modal-collaborator-item:hover,.project-modal-client-item:hover{background:#ffffff1a;border-color:#fff3;transform:translateY(-2px)}.project-modal-collaborator-image,.project-modal-client-image{object-fit:cover;object-position:center center;border:2px solid #fff3;border-radius:50%;flex-shrink:0;width:36px;height:36px}.project-modal-collaborator-name,.project-modal-client-name{color:#fff;font-size:.85rem;font-weight:500}.project-modal-actions{flex-direction:column;flex-shrink:0;gap:.5rem;margin-top:auto;padding-top:1rem;display:flex}.project-modal-btn{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;padding:.65rem 1rem;font-size:.9rem;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.project-modal-btn svg{width:20px;height:20px}.project-modal-btn-primary{color:#fff;background:linear-gradient(135deg,#14b8a6 0%,#0d9488 100%)}.project-modal-btn-primary:hover{background:linear-gradient(135deg,#0d9488 0%,#0f766e 100%);transform:translateY(-2px);box-shadow:0 4px 12px #14b8a666}.project-modal-btn-secondary{color:#fff;background:0 0;border:2px solid #fff}.project-modal-btn-secondary:hover{background:#ffffff1a;transform:translateY(-2px)}.project-modal-btn-disabled{opacity:.6;cursor:not-allowed;pointer-events:none}.project-modal-btn-close{color:#fff;background:#2a2a2a;border:1px solid #3a3a3a}.project-modal-btn-close:hover{background:#3a3a3a;transform:translateY(-2px)}.portfolio:not(.dark-mode) .project-modal-btn-close{background:#3a3a3a}.portfolio:not(.dark-mode) .project-modal-btn-close:hover{background:#4a4a4a}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(30px)}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.project-modal-overlay.closing{animation:.3s forwards fadeOut}.project-modal-content.closing{animation:.3s forwards slideDown}.project-image{position:relative}.project-category-tag{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;z-index:10;background:#000000b3;border-radius:20px;padding:.4rem .8rem;font-size:.75rem;font-weight:600;position:absolute;top:1rem;right:1rem}.project-tag-more{color:#4b5563;background:linear-gradient(135deg,#f8f9fa 0%,#f3f4f6 100%);border:1px solid #e5e5e5cc;border-radius:7px;padding:.5rem .9rem;font-size:.8rem;font-weight:600}.portfolio.dark-mode .project-tag-more{color:#94a3b8;background:linear-gradient(135deg,#2a2a2a 0%,#1a1a1a 100%);border-color:#3a3a3a}@media (max-width:968px){.project-modal-content{width:95%;height:90vh;max-height:90vh;overflow-y:auto}.project-modal-body{grid-template-columns:1fr;gap:1.5rem;height:auto;padding:1.5rem;overflow:visible}.project-modal-screenshots{order:1}.project-modal-details{order:2}.project-modal-category{display:none!important}.project-modal-logo{min-height:200px;max-height:200px;padding:1.5rem}.project-modal-logo-image{max-width:150px;max-height:150px}.project-modal-main-screenshot{min-height:300px}.project-modal-title{font-size:1.5rem}}@media (max-width:768px){.project-modal-overlay{padding:.5rem}.project-modal-content{scrollbar-width:none;-ms-overflow-style:none;border-radius:12px;width:95%;height:95vh;max-height:95vh;overflow-y:auto}.project-modal-content::-webkit-scrollbar{display:none}.project-modal-close{z-index:10002;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1a1a1ae6;width:36px;height:36px;position:sticky;top:0;right:1rem}.project-modal-close svg{width:20px;height:20px}.project-modal-body{gap:1rem;max-height:none;padding:1rem;overflow:visible}.project-modal-title{font-size:1.25rem}.project-modal-description{font-size:.9rem}.project-modal-category{display:none!important}.project-modal-logo{min-height:250px;max-height:250px;padding:1.5rem}.project-modal-logo-image{max-width:200px;max-height:200px}.project-modal-thumbnails{grid-template-columns:repeat(6,1fr);gap:.4rem}.project-modal-thumbnail{aspect-ratio:9/16}}.project-links{gap:1.5rem;display:flex}.project-link{color:#14b8a6;align-items:center;gap:.5rem;padding:.5rem 0;font-size:.9rem;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.project-link:hover{color:#0d9488;text-decoration:underline}.project-link-icon{flex-shrink:0;width:18px;height:18px}.skills{background:#fff;box-shadow:0 1px 3px #0000000d}.skills-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;display:grid}.skill-category{background:linear-gradient(135deg,#fff 0%,#f8fafc 100%);border:1px solid #e5e7eb;border-radius:16px;padding:2.25rem;transition:all .3s;position:relative;overflow:hidden;box-shadow:0 2px 8px #0000000f,0 1px 2px #0000000a}.skill-category:before{content:"";opacity:0;background:linear-gradient(90deg,#14b8a6,#0d9488);height:3px;transition:opacity .3s;position:absolute;top:0;left:0;right:0}.skill-category:hover{border-color:#14b8a6;transform:translateY(-4px);box-shadow:0 8px 24px #0000001a,0 4px 12px #14b8a61a}.skill-category:hover:before{opacity:1}.skill-category h3{color:#0f172a;margin-bottom:1.5rem;font-size:1.25rem;font-weight:700}.skill-items{flex-wrap:wrap;gap:.75rem;display:flex}.skill-item{color:#475569;background:#fff;border:1px solid #e5e7eb;border-radius:10px;align-items:center;gap:.625rem;padding:.625rem 1.125rem;font-size:.9rem;font-weight:600;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 1px 3px #0000000a,0 1px 1px #00000005}.skill-icon{color:#4b5563;flex-shrink:0;width:18px;height:18px;transition:all .2s}.skill-item:hover{color:#fff;background:#14b8a6;border-color:#14b8a6;transform:translateY(-2px);box-shadow:0 4px 8px #14b8a633}.skill-item:hover .skill-icon{color:#fff}.certificates{background:#fff}.certificates-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));justify-items:center;gap:2.5rem;max-width:1000px;margin:0 auto;display:grid}.certificate-card{cursor:pointer;background:#fff;border:1.5px solid #e5e5e5cc;border-radius:16px;flex-direction:column;width:100%;max-width:400px;transition:all .4s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden;box-shadow:0 2px 8px #0000000f,inset 0 1px #fffc}.certificate-card:before{content:"";opacity:0;z-index:1;background:linear-gradient(90deg,#14b8a6,#0d9488);height:3px;transition:opacity .3s;position:absolute;top:0;left:0;right:0}.certificate-card:hover{border-width:1.5px;border-color:#14b8a6;transform:translateY(-10px);box-shadow:0 12px 32px #0000001f,0 4px 16px #14b8a626}.certificate-card:hover:before{opacity:1}.certificate-preview{background:#f3f4f6;width:100%;height:300px;position:relative;overflow:hidden}.certificate-preview-pdf{pointer-events:none;border:none;width:100%;height:100%}.certificate-preview-iframe{display:none}.certificate-preview-object{display:block}.certificate-preview-image{object-fit:cover;pointer-events:none;width:100%;height:100%}.certificate-placeholder{background:#f8f9fa;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.certificate-icon{opacity:.5;margin-bottom:.5rem;font-size:3rem}.certificate-placeholder p{color:#9ca3af;font-size:.9rem}.certificate-overlay{opacity:0;background:#0006;justify-content:center;align-items:center;width:100%;height:100%;transition:opacity .3s;display:flex;position:absolute;top:0;left:0}.certificate-card:hover .certificate-overlay{opacity:1}.certificate-view-text{color:#fff;text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#14b8a6f2 0%,#0d9488f2 100%);border-radius:10px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;box-shadow:0 4px 12px #0003}.portfolio.dark-mode .certificate-view-text{background:linear-gradient(135deg,#94a3b8f2 0%,#64748bf2 100%)}.certificate-info{text-align:center;padding:2rem}.certificate-info h3{color:#1a1a1a;letter-spacing:-.3px;margin-bottom:.75rem;font-size:1.3rem;font-weight:700;line-height:1.3}.certificate-info p{color:#6b7280;margin-bottom:.5rem;font-size:.95rem}.certificate-date{color:#9ca3af;margin-bottom:0;font-size:.85rem}.certificate-modal{z-index:2000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#000000e6;justify-content:center;align-items:center;width:100%;height:100%;padding:2rem;display:flex;position:fixed;top:0;left:0}.certificate-modal-content{background:#fff;border-radius:12px;flex-direction:column;max-width:95%;max-height:95%;padding:0;display:flex;position:relative;overflow:hidden;box-shadow:0 20px 60px #00000080}.certificate-modal-close{color:#fff;cursor:pointer;z-index:2001;background:#000000b3;border:none;border-radius:50%;justify-content:center;align-items:center;width:45px;height:45px;font-size:1.75rem;font-weight:300;line-height:1;transition:all .2s;display:flex;position:absolute;top:1rem;right:1rem}.certificate-modal-close:hover{background:#000000e6;transform:scale(1.1)}.certificate-image{border-radius:0;max-width:100%;height:auto;display:block}.certificate-pdf-container{background:#fff;flex-direction:column;align-items:center;width:100%;max-height:90vh;padding:1rem;display:flex;position:relative;overflow-y:auto}.certificate-pdf-container iframe,.certificate-pdf-container object,.certificate-pdf-container embed{display:none!important}.certificate-pdf-container [class*=permission],.certificate-pdf-container [id*=permission],.certificate-pdf-container [aria-label*=permission],.certificate-pdf-container [class*=limited],.certificate-pdf-container [id*=limited]{visibility:hidden!important;opacity:0!important;width:0!important;height:0!important;display:none!important;overflow:hidden!important}.certificate-pdf-container *{position:relative}:is(.certificate-pdf-container :has-text("permission"),.certificate-pdf-container :has-text("limited"),.certificate-pdf-container :has-text("View permissions")){visibility:hidden!important;display:none!important}.certificate-pdf-container:before,.certificate-pdf-container:after{content:none!important}@media (max-width:768px){.certificate-preview-canvas-container{z-index:1;width:100%;height:100%;position:absolute;top:0;left:0;display:block!important}.certificate-preview-canvas{object-fit:contain;width:100%;height:auto;display:block}.certificate-preview-iframe,.certificate-preview-object,.certificate-overlay,.certificate-card:hover .certificate-overlay{display:none!important}.certificate-preview{height:400px;position:relative;overflow:hidden}.certificate-preview-pdf{border:none;width:100%;height:100%;display:block}.certificate-preview object:after,.certificate-preview embed:after,.certificate-preview object:before,.certificate-preview embed:before{display:none!important}.certificate-preview object,.certificate-preview embed{appearance:none}.certificate-preview *{-webkit-user-select:none;user-select:none}.certificate-preview a[download],.certificate-preview a[href$=\.pdf],.certificate-preview a{display:none!important}.certificate-preview:after,.certificate-preview:before,.certificate-preview iframe:before,.certificate-preview iframe:after{content:none!important;display:none!important}.certificate-preview-iframe{background:0 0}}.certificate-modal-content>:not(.certificate-pdf-container):not(.certificate-modal-close){position:relative}.certificate-pdf-canvas{border-radius:4px;max-width:100%;height:auto;display:block;box-shadow:0 4px 12px #0000001a}.certificate-loading{text-align:center;color:#6b7280;padding:3rem;font-size:1.1rem}.project-screenshots-page{background:linear-gradient(135deg,#f0fdfa 0%,#fff 30%,#f0fdfa 60%,#fff 100%);min-height:100vh;padding:8rem 0 4rem;position:relative}.project-screenshots-header{text-align:center;margin-bottom:4rem;position:relative}.back-button-mobile{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:.75rem;transition:all .3s;display:none;position:absolute;top:50%;left:0;transform:translateY(-50%);box-shadow:0 2px 4px #0000001a}.back-button-mobile:hover{background:#f0fdfa;border-color:#14b8a6;transform:translateY(-50%)translate(-2px)}.back-button-mobile svg{color:#14b8a6;width:20px;height:20px}.project-screenshots-page-title{color:#0f172a;letter-spacing:-1.5px;background:linear-gradient(135deg,#0f172a 0%,#14b8a6 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem;font-size:3rem;font-weight:800;line-height:1.2}.project-screenshots-subtitle{color:#475569;font-size:1.25rem;font-weight:500}.back-to-projects-btn{color:#475569;cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:10px;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;transition:all .3s;display:flex;box-shadow:0 2px 4px #0000000a}.back-to-projects-btn:hover{color:#14b8a6;background:#f0fdfa;border-color:#14b8a6;transform:translate(-2px)}.back-to-projects-btn svg{width:18px;height:18px}.project-screenshots-grid{grid-template-columns:1fr;gap:2rem;margin-bottom:4rem;display:grid}@media (min-width:768px){.project-screenshots-grid{grid-template-columns:repeat(2,1fr);gap:2rem}}@media (min-width:1024px){.project-screenshots-grid{grid-template-columns:repeat(3,1fr);gap:2.5rem}}@media (min-width:1440px){.project-screenshots-grid{grid-template-columns:repeat(4,1fr);gap:2.5rem}}.project-screenshot-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 4px 16px #00000014,0 2px 4px #0000000a}.project-screenshot-card:hover{border-color:#14b8a6;transform:translateY(-8px);box-shadow:0 12px 32px #0000001f,0 4px 16px #14b8a626}.project-screenshot-full{object-fit:contain;background:#f8f9fa;width:100%;height:auto;display:block}.project-screenshots-footer{text-align:center;border-top:1px solid #e5e7eb;padding-top:2rem}.project-screenshots-footer .btn{align-items:center;gap:.5rem;display:inline-flex}.project-screenshots-footer .btn svg{width:18px;height:18px}.portfolio.dark-mode .project-screenshots-page{background:linear-gradient(135deg,#0f0f0f 0%,#1a1a1a 30%,#0f0f0f 60%,#1a1a1a 100%)}.portfolio.dark-mode .project-screenshots-page-title{background:linear-gradient(135deg,#fff 0%,#14b8a6 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.portfolio.dark-mode .project-screenshots-subtitle{color:#94a3b8}.portfolio.dark-mode .back-to-projects-btn{color:#e5e5e5;background:#1a1a1a;border-color:#2a2a2a}.portfolio.dark-mode .back-to-projects-btn:hover{color:#14b8a6;background:#2a2a2a;border-color:#14b8a6}.portfolio.dark-mode .back-button-mobile{background:#1a1a1a;border-color:#2a2a2a}.portfolio.dark-mode .back-button-mobile:hover{background:#2a2a2a;border-color:#14b8a6}.portfolio.dark-mode .project-screenshot-card{background:#1a1a1a;border-color:#2a2a2a}.portfolio.dark-mode .project-screenshot-full{background:#0f0f0f}.portfolio.dark-mode .project-screenshots-footer{border-top-color:#2a2a2a}.contact{background:#f1f5f9}.contact-content{text-align:center;max-width:600px;margin:0 auto}.contact-description{color:#475569;max-width:600px;margin-bottom:3.5rem;margin-left:auto;margin-right:auto;font-size:1.15rem;font-weight:400;line-height:1.85}.contact-info{flex-direction:column;gap:1rem;display:flex}.contact-item{color:#0f172a;background:linear-gradient(135deg,#fff 0%,#f8fafc 100%);border:1px solid #e5e7eb;border-radius:14px;justify-content:center;align-items:center;gap:1rem;padding:1.5rem;font-size:1rem;font-weight:600;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden;box-shadow:0 2px 6px #0000000a,0 1px 2px #00000005}.contact-item:before{content:"";opacity:0;background:linear-gradient(90deg,#14b8a6,#0d9488);height:3px;transition:opacity .3s;position:absolute;top:0;left:0;right:0}.portfolio.dark-mode .contact-item:before{background:linear-gradient(90deg,#94a3b8,#64748b)}.contact-item:hover{background:linear-gradient(135deg,#f0fdfa 0%,#ccfbf1 100%);border-color:#14b8a6;transform:translateY(-4px);box-shadow:0 8px 20px #14b8a626}.contact-item:hover:before{opacity:1}.contact-icon{color:#1a1a1a;flex-shrink:0;width:24px;height:24px;transition:all .2s}.contact-item:hover .contact-icon{color:#14b8a6;transform:scale(1.1)}.footer{text-align:center;color:#9ca3af;background:linear-gradient(135deg,#1a1a1a 0%,#0f0f0f 100%);border-top:1px solid #ffffff0d;padding:3rem 0;font-size:.9rem;position:relative}.footer:before{content:"";background:linear-gradient(90deg,#0000,#14b8a64d,#0000);height:1px;position:absolute;top:0;left:0;right:0}.portfolio.dark-mode .footer:before{background:linear-gradient(90deg,#0000,#94a3b84d,#0000)}@media (min-width:769px) and (max-width:1024px){.hero-name{font-size:2.4rem}.hero-buttons{flex-wrap:nowrap;justify-content:flex-start}.btn{white-space:nowrap;padding:.75rem 1.25rem;font-size:.9rem}}@media (max-width:768px){.nav-container{padding:0 1.5rem;position:relative}.nav-right{gap:1rem}.mobile-menu-toggle{display:block}.theme-toggle{border-radius:6px;width:38px;height:38px;font-size:1.1rem}.theme-toggle-mobile{width:40px;height:40px;font-size:1.15rem}.theme-toggle-desktop{display:none}.theme-toggle-mobile,.mobile-menu-header{display:flex}.nav-menu{-webkit-backdrop-filter:blur(20px)saturate(180%);transform-origin:100% 0;opacity:0;z-index:999;background:#ffffffbf;border:1px solid #e5e5e580;border-radius:12px;flex-direction:column;gap:0;width:calc(100% - 3rem);max-width:320px;max-height:calc(100vh - 90px);padding:0;transition:transform .3s cubic-bezier(.34,1.56,.64,1),opacity .3s;position:fixed;top:70px;right:1.5rem;overflow-y:auto;transform:scale(0)translateY(-20px);box-shadow:0 4px 20px #00000026}.nav-menu.active{opacity:1;transform:scale(1)translateY(0)}.nav-menu li{border-bottom:1px solid #f0f0f0;width:100%}.nav-menu li:last-child{border-bottom:none}.nav-menu a{width:100%;padding:1rem 2rem;font-size:1rem;display:block}.nav-menu a:after{display:none}.nav-menu a:hover{background:#f8f9fa}.hero{min-height:auto;padding:6rem 1.5rem 3rem}.hero-content{text-align:center;grid-template-columns:1fr;gap:2.5rem}.hero-text{text-align:center}.hero-name{word-wrap:break-word;font-size:2rem;line-height:1.2}.hero-title{margin-bottom:1rem;font-size:1.25rem}.hero-description{max-width:100%;font-size:1rem;line-height:1.6}.image-placeholder{width:250px;height:250px;margin:0 auto}.hero-buttons{flex-direction:column;gap:.75rem}.btn{width:100%;max-width:300px;margin:0 auto}.section-title{margin-bottom:3rem;font-size:2rem}section{padding:4rem 0;scroll-margin-top:67px}.container{padding:0 1.5rem}.projects-grid{grid-template-columns:1fr;gap:1.5rem}.project-card{width:100%}.project-screenshots-page{padding:6rem 0 3rem}.project-screenshots-header{margin-bottom:2.5rem;padding:0 1rem}.back-button-mobile{display:flex}.back-to-projects-btn{display:none}.project-screenshots-page-title{padding-left:3rem;font-size:2rem}.project-screenshots-subtitle{padding-left:3rem;font-size:1rem}.project-screenshots-grid{grid-template-columns:1fr;gap:1.5rem;padding:0 1rem}.project-screenshot-card{border-radius:12px}.skills-grid{grid-template-columns:1fr;gap:1.5rem}.skill-category{width:100%}.about-text p{font-size:1rem}}@media (max-width:480px){.nav-container{padding:0 1rem}.logo{flex:1;font-size:1.1rem}.nav-right{gap:.75rem}.theme-toggle{border-radius:6px;width:36px;height:36px;font-size:1rem}.theme-toggle-mobile{width:38px;height:38px;font-size:1.1rem}.mobile-menu-header{padding:1rem 1.5rem}.nav-menu{top:65px}.nav-menu a{padding:.875rem 1.5rem;font-size:.95rem}.hero{min-height:calc(100vh - 65px);padding:5rem 1rem 2rem}.hero-content{gap:2rem}.container{padding:0 1rem}.hero-name{font-size:1.75rem;line-height:1.2}.hero-title{margin-bottom:1rem;font-size:1.1rem}.hero-description{margin-bottom:2rem;font-size:.95rem;line-height:1.6}.image-placeholder{width:220px;height:220px}.hero-buttons{flex-direction:column;width:100%}.btn{width:100%;padding:.875rem 1.5rem}.image-placeholder span{font-size:3rem}.image-placeholder p{padding:0 1rem;font-size:.75rem}.section-title{margin-bottom:2.5rem;font-size:1.75rem;line-height:1.3}section{padding:3rem 0;scroll-margin-top:67px}.about-text p{font-size:.95rem;line-height:1.7}.project-card{margin-bottom:0}.project-info{padding:1.5rem}.project-info h3{font-size:1.25rem;line-height:1.3}.project-info p{font-size:.9rem;line-height:1.6}.project-tags{gap:.4rem}.project-tags span{padding:.3rem .7rem;font-size:.75rem}.project-tag-hidden-desktop{display:inline-block}.project-tag-more-desktop{display:none}.project-links{flex-direction:column;gap:.75rem}.project-link{text-align:center;padding:.5rem;display:block}.skill-category{padding:1.5rem}.skill-category h3{margin-bottom:1.25rem;font-size:1.1rem}.skill-item{padding:.45rem .9rem;font-size:.85rem}.contact-item{text-align:center;flex-direction:column;gap:.5rem;padding:1rem;font-size:.9rem}.contact-icon{font-size:1.25rem}.btn{padding:.875rem 1.5rem;font-size:.9rem}}@media (max-width:360px){.nav-container{padding:0 .75rem}.logo{font-size:1rem}.theme-toggle{width:30px;height:30px;font-size:.9rem}.hero{padding:4.5rem .75rem 2rem}.container{padding:0 .75rem}.hero-name{font-size:1.75rem;line-height:1.2}.hero-title{font-size:1rem}.hero-description{font-size:.9rem}.hero-stats{gap:1.5rem;margin-top:2rem;margin-bottom:1.5rem;padding-top:1.5rem}.stat-number{font-size:1.5rem}.stat-label{font-size:.75rem}.hero-tech-stack{gap:.5rem;margin-top:1rem}.tech-badge{padding:.375rem .75rem;font-size:.75rem}.section-title{margin-bottom:2rem;font-size:1.5rem}.image-placeholder{width:180px;height:180px}section{padding:2.5rem 0;scroll-margin-top:67px}.project-info,.skill-category{padding:1.25rem}.contact-item{padding:.875rem;font-size:.85rem}}.portfolio.dark-mode .navbar{background:#0f0f0ff2;border-bottom:1px solid #1a1a1a;box-shadow:0 1px 3px #0000004d}.portfolio.dark-mode .logo{background:linear-gradient(135deg,#94a3b8 0%,#64748b 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.portfolio.dark-mode .nav-menu a{color:#a0a0a0}.portfolio.dark-mode .nav-menu a:hover{color:#94a3b8}.portfolio.dark-mode .nav-menu a:after{opacity:0;pointer-events:none;background:#94a3b8;width:0}.portfolio.dark-mode .nav-menu a:hover:after{opacity:1;width:100%}.portfolio.dark-mode .theme-toggle:hover{background:#1a1a1a;border-color:#4a4a4a}.portfolio.dark-mode .image-placeholder{background:#1a1a1a;border-color:#2a2a2a;box-shadow:0 4px 20px #00000080}.portfolio.dark-mode .btn-secondary{color:#94a3b8;border-color:#94a3b8}.portfolio.dark-mode .btn-secondary:hover{background:#94a3b81a}.portfolio.dark-mode .section-title{color:#e5e5e5}.portfolio.dark-mode .filter-btn{color:#a0a0a0;background:#1a1a1a;border-width:1.5px;border-color:#2a2a2a;box-shadow:0 1px 2px #0003}.portfolio.dark-mode .filter-btn.active:hover{background:linear-gradient(135deg,#475569 0%,#334155 100%);border-color:#475569}.portfolio.dark-mode .project-card{background:#1a1a1a;border-width:1.5px;border-color:#2a2a2a;box-shadow:0 1px 4px #0000004d}.portfolio.dark-mode .project-card:hover{border-width:1.5px;border-color:#94a3b8;box-shadow:0 8px 20px #00000080}.portfolio.dark-mode .project-image{background:#0f0f0f}.portfolio.dark-mode .image-placeholder-small{color:#4a4a4a}.portfolio.dark-mode .project-tags span{color:#a0a0a0;background:#2a2a2a;border:1px solid #3a3a3a}.portfolio.dark-mode .project-link{color:#94a3b8}.portfolio.dark-mode .project-link:hover{color:#cbd5e1}.portfolio.dark-mode .skill-category{background:#0f0f0f;border-width:1.5px;border-color:#2a2a2a;box-shadow:0 1px 4px #0000004d}.portfolio.dark-mode .skill-item{color:#a0a0a0;background:#1a1a1a;border-width:1px;border-color:#2a2a2a}.portfolio.dark-mode .skill-item:hover{color:#fff;background:linear-gradient(135deg,#64748b 0%,#475569 100%);border-color:#64748b}.portfolio.dark-mode .skill-icon{color:#a0a0a0}.portfolio.dark-mode .skill-item:hover .skill-icon{color:#fff}.portfolio.dark-mode .certificates{background:#1a1a1a}.portfolio.dark-mode .certificate-card{background:#1a1a1a;border-width:1.5px;border-color:#2a2a2a}.portfolio.dark-mode .certificate-card:hover{border-width:1.5px;border-color:#94a3b8;box-shadow:0 8px 20px #00000080}.portfolio.dark-mode .certificate-preview,.portfolio.dark-mode .certificate-placeholder{background:#0f0f0f}.portfolio.dark-mode .certificate-info h3{color:#e5e5e5}.portfolio.dark-mode .certificate-info p{color:#9ca3af}.portfolio.dark-mode .certificate-date{color:#6b7280}.portfolio.dark-mode .certificate-modal-content,.portfolio.dark-mode .certificate-pdf{background:#1a1a1a}.portfolio.dark-mode .certificate-modal-close{color:#1a1a1a;background:#ffffffe6;border:2px solid #ffffff4d}.portfolio.dark-mode .certificate-modal-close:hover{color:#1a1a1a;background:#fff;transform:scale(1.1)}.portfolio.dark-mode .contact{background:#0f0f0f}.portfolio.dark-mode .contact-description{color:#a0a0a0}.portfolio.dark-mode .contact-item{color:#e5e5e5;background:#1a1a1a;border-color:#2a2a2a}.portfolio.dark-mode .contact-icon{color:#e5e5e5}.portfolio.dark-mode .contact-item:hover .contact-icon{color:#94a3b8}.portfolio.dark-mode .contact-item:hover{background:#2a2a2a;border-color:#3a3a3a;box-shadow:0 4px 12px #0000004d}.portfolio.dark-mode .footer{background:#0a0a0a;border-top:1px solid #2a2a2a}.portfolio.dark-mode .theme-toggle{color:#e5e5e5;border-color:#3a3a3a}.portfolio.dark-mode .theme-toggle:hover{background:#1a1a1a;border-color:#94a3b8;box-shadow:0 2px 8px #94a3b833}.portfolio.dark-mode .mobile-menu-header{border-bottom:1px solid #2a2a2a}.portfolio.dark-mode .hamburger span{background:#e5e5e5}.portfolio.dark-mode .nav-menu{-webkit-backdrop-filter:blur(20px)saturate(180%);background:#0f0f0fbf;border:1px solid #2a2a2a80}.portfolio.dark-mode .nav-menu li{border-bottom:1px solid #2a2a2a}.portfolio.dark-mode .nav-menu a:hover{background:#1a1a1a}@media (max-width:768px){.portfolio.dark-mode .theme-toggle{width:36px;height:36px;font-size:1.1rem}}@media (max-width:480px){.portfolio.dark-mode .theme-toggle{width:32px;height:32px;font-size:1rem}}@media (max-width:360px){.portfolio.dark-mode .theme-toggle{width:30px;height:30px;font-size:.9rem}}.fade-in{opacity:0;transition:opacity .6s,transform .6s;transform:translateY(20px)}.fade-in-visible,.project-card.expanded.fade-in,.project-card.expanded.fade-in-visible{opacity:1;transform:translateY(0)}.back-to-top{color:#fff;cursor:pointer;z-index:999;opacity:0;pointer-events:none;background:#14b8a6;border:none;border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;transition:all .3s;display:flex;position:fixed;bottom:2rem;right:2rem;transform:translateY(20px);box-shadow:0 4px 12px #14b8a64d}.back-to-top.show{opacity:1;pointer-events:all;transform:translateY(0)}.back-to-top:hover{background:#0d9488;transform:translateY(-3px);box-shadow:0 6px 16px #14b8a666}.back-to-top:active{transform:translateY(-1px)}.back-to-top svg{width:24px;height:24px}.portfolio.dark-mode .back-to-top{background:linear-gradient(135deg,#64748b 0%,#475569 100%);box-shadow:0 4px 12px #64748b66}.portfolio.dark-mode .back-to-top:hover{background:linear-gradient(135deg,#475569 0%,#334155 100%);box-shadow:0 6px 16px #64748b80}.portfolio.dark-mode{color:#e5e5e5;background:#0a0a0a}.portfolio.dark-mode .hero{background:linear-gradient(#0f0f0f 0%,#0a0a0a 100%)}.portfolio.dark-mode .hero-name{background:linear-gradient(135deg,#fff 0%,#cbd5e1 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.portfolio.dark-mode .hero-title{color:#d1d5db}.portfolio.dark-mode .hero-description{color:#9ca3af}.portfolio.dark-mode .about{background:#0f0f0f}.portfolio.dark-mode .about-text p{color:#d1d5db}.portfolio.dark-mode .projects{background:#0f0f0f}.portfolio.dark-mode .project-card{background:#1a1a1a;border-color:#2a2a2a}.portfolio.dark-mode .project-card:hover{border-color:#94a3b8;box-shadow:0 8px 20px #0006}.portfolio.dark-mode .project-card:before,.portfolio.dark-mode .skill-category:before,.portfolio.dark-mode .certificate-card:before{background:linear-gradient(90deg,#94a3b8,#64748b)}.portfolio.dark-mode .project-info h3{color:#fff}.portfolio.dark-mode .project-info p{color:#d1d5db}.portfolio.dark-mode .project-tags span{color:#d1d5db;background:#2a2a2a}.portfolio.dark-mode .skills{background:#0f0f0f}.portfolio.dark-mode .skill-category h3{color:#fff}.portfolio.dark-mode .skill-item{color:#e5e5e5;background:#1a1a1a;border-color:#2a2a2a}.portfolio.dark-mode .skill-item:hover{background:#2a2a2a;border-color:#94a3b8}.portfolio.dark-mode .filter-btn{color:#d1d5db;background:#1a1a1a;border-color:#2a2a2a}.portfolio.dark-mode .filter-btn:hover{color:#94a3b8;background:#94a3b81a;border-color:#94a3b8}.portfolio.dark-mode .filter-btn.active{color:#fff;background:linear-gradient(135deg,#64748b 0%,#475569 100%);border-color:#64748b}:focus-visible,button:focus-visible,a:focus-visible{outline-offset:2px;outline:2px solid #14b8a6}.skip-to-main{z-index:9999;position:absolute;left:-9999px}.skip-to-main:focus{color:#fff;background:#14b8a6;border-radius:4px;padding:1rem 2rem;text-decoration:none;left:50%;transform:translate(-50%)}@media (max-width:768px){.back-to-top{width:45px;height:45px;bottom:1.5rem;right:1.5rem}.back-to-top svg{width:20px;height:20px}}@media (max-width:480px){.back-to-top{width:40px;height:40px;bottom:1rem;right:1rem}.back-to-top svg{width:18px;height:18px}}
