*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,Arial,sans-serif;background-color:#1a202c;color:#e2e8f0;line-height:1.6}.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}@media (max-width: 768px){.container{padding:0 .5rem;max-width:100%}}.section{padding:3rem 0}@media (max-width: 768px){.section{padding:1.5rem 0}}.section-title{font-size:2rem;font-weight:700;margin-bottom:1.5rem;color:#63b3ed;position:relative}@media (max-width: 768px){.section-title{font-size:1.75rem;margin-bottom:.75rem}}.section-title:after{content:"";position:absolute;bottom:-.5rem;left:0;width:50px;height:3px;background-color:#63b3ed}.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}@media (max-width: 768px){.card-grid{grid-template-columns:1fr;gap:1rem}}.card{background-color:#2d3748;border-radius:.75rem;padding:1.5rem;box-shadow:0 4px 12px #0000004d;transition:transform .3s ease;border:1px solid #4a5568}@media (max-width: 768px){.card{padding:1rem;border-radius:.5rem}}.card:hover{transform:translateY(-5px)}#about .card,#education .card{background-color:transparent;border:none;box-shadow:none;padding:0;border-radius:0}@media (max-width: 768px){#about .card,#education .card{padding:0}}#about .card:hover,#education .card:hover{transform:none}#projects .card{background-color:transparent;border:none;box-shadow:none;border-radius:0;padding:1.5rem 0;border-bottom:1px solid #4a5568}@media (max-width: 768px){#projects .card{padding:.75rem 0}}#projects .card:last-child{border-bottom:none}#projects .card:hover{transform:none;background-color:#63b3ed0d;border-radius:.5rem;padding:1.5rem;margin:0 -1.5rem}@media (max-width: 768px){#projects .card:hover{padding:.75rem;margin:0 -.5rem}}.card h3{font-size:1.25rem;font-weight:600;margin-bottom:1rem;color:#e2e8f0}@media (max-width: 768px){.card h3{font-size:1.1rem;margin-bottom:.5rem}}.card p{color:#cbd5e0;font-size:.95rem;margin-bottom:1rem}@media (max-width: 768px){.card p{font-size:.9rem;margin-bottom:.5rem;line-height:1.4}}.project-image{width:100%;height:180px;object-fit:cover;border-radius:.5rem;margin-bottom:1rem}@media (max-width: 768px){.project-image{height:140px;margin-bottom:.5rem}}.tech-stack{font-size:.9rem;color:#a0aec0}@media (max-width: 768px){.tech-stack{font-size:.85rem}}.project-link{color:#63b3ed;font-weight:600;text-decoration:none}.project-link:hover{text-decoration:underline;color:#90cdf4}.contact-form{display:flex;flex-direction:column;gap:1.5rem;max-width:600px;margin:0 auto}@media (max-width: 768px){.contact-form{gap:1rem;max-width:100%;margin:0}}.contact-form label{display:block;margin-bottom:.5rem;font-weight:600;color:#e2e8f0;font-size:.95rem}@media (max-width: 768px){.contact-form label{margin-bottom:.25rem;font-size:.9rem}}.contact-form input,.contact-form textarea{padding:.75rem;border:1px solid #4a5568;border-radius:.5rem;font-size:1rem;transition:border-color .3s ease;background-color:#2d3748;color:#e2e8f0;width:100%}@media (max-width: 768px){.contact-form input,.contact-form textarea{padding:.6rem;font-size:.95rem}}.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:#63b3ed;background-color:#374151}.contact-form input::placeholder,.contact-form textarea::placeholder{color:#a0aec0}.contact-form button{background-color:#63b3ed;color:#1a202c;padding:.75rem 1.5rem;border:none;border-radius:.5rem;cursor:pointer;transition:all .3s ease;font-weight:600;font-size:1rem;margin-top:.5rem}.contact-form button:hover:not(:disabled){background-color:#90cdf4;transform:translateY(-1px)}.contact-form button:disabled{opacity:.6;cursor:not-allowed;transform:none}.status-message{padding:.75rem;border-radius:.5rem;text-align:center;font-weight:500;margin-top:.5rem}@media (max-width: 768px){.status-message{padding:.6rem;margin-top:.25rem}}.status-message.success{background-color:#48bb781a;color:#68d391;border:1px solid rgba(72,187,120,.3)}.status-message.error{background-color:#f565651a;color:#fc8181;border:1px solid rgba(245,101,101,.3)}.footer{text-align:center;padding:2rem 0;background-color:#1a202c;color:#e2e8f0}@media (max-width: 768px){.footer{padding:1.5rem 0}}.footer p{font-size:.9rem}.footer .status{font-size:.85rem;color:#a0aec0;margin-top:.5rem}@media (max-width: 768px){body{font-size:14px}*{max-width:100%}}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}@media (max-width: 768px){#root{padding:.5rem .25rem;max-width:100%}}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}@media (max-width: 768px){.logo{height:4em;padding:.5em}}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}@media (max-width: 768px){.card{padding:1.25em}}.read-the-docs{color:#888}.modal-overlay{position:fixed;inset:0;background:#14181fd9;display:flex;justify-content:center;align-items:center;z-index:10000;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background-color:#2d3748;border-radius:1rem;padding:2rem;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px #00000080;border:1px solid #4a5568;animation:modalFadeIn .3s ease-out}.modal-close{position:absolute;top:1.2rem;right:1.2rem;background:transparent;color:#e2e8f0;border:none;font-size:2rem;cursor:pointer;opacity:.5;transition:opacity .2s,color .2s;z-index:2;padding:.1rem .6rem;line-height:1}.modal-close:hover{background-color:#ef444426;color:#f56565;transform:scale(1.1);border:1px solid rgba(239,68,68,.3)}.modal-close:active{background-color:#ef444440;transform:scale(.95);transition:all .1s ease}.modal-close:focus{outline:2px solid #63b3ed;outline-offset:2px}.modal-close svg{width:20px;height:20px;pointer-events:none;transition:transform .2s ease;fill:currentColor}.modal-close:hover svg{transform:rotate(90deg) scale(1.1)}@keyframes modalFadeIn{0%{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-content .section{padding:0;margin:0}.modal-content .section-title{color:#63b3ed;margin-bottom:2rem;text-align:center;margin-top:0}.modal-content .section-title:after{left:50%;transform:translate(-50%)}.modal-content .card{background-color:transparent;border:none;box-shadow:none;padding:0;border-radius:0}.modal-content .card:hover{transform:none}.image-modal-content{position:relative;background:transparent;box-shadow:none;padding:0;border:none;display:flex;flex-direction:column;align-items:center;max-width:95vw;max-height:95vh;justify-content:center}.modal-image{max-width:90vw;max-height:80vh;border-radius:1rem;box-shadow:none;background:transparent;border:none;display:block;transition:transform .25s cubic-bezier(.4,2,.6,1),box-shadow .2s}.modal-image.zoomed{transform:scale(2)!important;z-index:10;box-shadow:0 8px 40px #000a;cursor:zoom-out;max-width:none;max-height:none}.image-modal-close{position:absolute;top:.5rem;right:.5rem;background:#2c3e50b3;color:#e2e8f0;border:none;font-size:1.7rem;cursor:pointer;opacity:.7;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;z-index:2;transition:opacity .2s,background .2s,color .2s;padding:0;line-height:1}.image-modal-close:hover,.image-modal-close:focus{opacity:1;color:#63b3ed;background:#2c3e50f2;outline:none}@media (max-width: 768px){.image-modal-close{top:.2rem;right:.2rem;width:40px;height:40px;font-size:2rem}}body.modal-open{overflow:hidden}.notification-content{text-align:center;padding:2rem;max-width:400px;margin:0 auto}.notification-header{margin-bottom:1.5rem}.notification-icon{margin-bottom:1rem;display:block;margin-left:auto;margin-right:auto}.notification-icon.success{color:#10b981}.notification-icon.error{color:#ef4444}.notification-icon.warning{color:#f59e0b}.notification-icon.info{color:#3b82f6}.notification-title{font-size:1.5rem;font-weight:600;margin:0;color:var(--text-color)}.notification-content.success .notification-title{color:#10b981}.notification-content.error .notification-title{color:#ef4444}.notification-content.warning .notification-title{color:#f59e0b}.notification-content.info .notification-title{color:#3b82f6}.notification-body{margin-bottom:2rem}.notification-message{font-size:1rem;color:var(--text-color);opacity:.8;line-height:1.6;margin:0}.notification-actions{display:flex;justify-content:center;gap:1rem}.notification-button{padding:.75rem 2rem;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .3s ease;font-size:1rem}.notification-button.success{background-color:#10b981;color:#fff}.notification-button.success:hover{background-color:#059669;transform:translateY(-2px)}.notification-button.error{background-color:#ef4444;color:#fff}.notification-button.error:hover{background-color:#dc2626;transform:translateY(-2px)}.notification-button.warning{background-color:#f59e0b;color:#fff}.notification-button.warning:hover{background-color:#d97706;transform:translateY(-2px)}.notification-button.info{background-color:#3b82f6;color:#fff}.notification-button.info:hover{background-color:#2563eb;transform:translateY(-2px)}.notification-content{animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.user-dropdown{position:relative;display:inline-block}.user-dropdown-toggle{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;cursor:pointer;transition:all .2s ease;font-size:.9rem}.user-dropdown-toggle:hover{background:#ffffff26;transform:translateY(-1px)}.user-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.75rem;color:#fff}.user-avatar.large{width:40px;height:40px;font-size:1rem}.user-name{font-weight:500;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-arrow{transition:transform .2s ease}.user-dropdown-menu{position:absolute;top:100%;right:0;margin-top:.5rem;background:#f9fafb;border-radius:14px;box-shadow:0 10px 40px #0000001f;border:1px solid #cbd5e1;min-width:280px;z-index:1000;animation:slideDown .2s ease-out;padding-bottom:.5rem}.dropdown-header{padding:1rem;background:#e3e8f0;border-top-left-radius:14px;border-top-right-radius:14px}.user-info{display:flex;align-items:center;gap:.75rem}.user-details{display:flex;flex-direction:column;gap:.25rem}.user-full-name{font-weight:600;color:#1a202c;font-size:.95rem}.user-email{font-size:.85rem;color:#718096}.admin-badge{display:inline-block;background:#4f46e5;color:#fff;padding:.15rem .6rem;border-radius:6px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.7px}.dropdown-divider{height:1px;background:#cbd5e1;margin:0}.dropdown-items{padding:.5rem 0}.dropdown-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:none;border:none;text-align:left;color:#2d3748;text-decoration:none;font-size:.95rem;cursor:pointer;transition:background-color .18s;border-radius:6px}.dropdown-item:hover{background-color:#e3e8f0}.dropdown-item[href="/admin"]{color:#3b2ae3;font-weight:600}.dropdown-item[href="/admin"]:hover{background-color:#e3e8f0;color:#241a7a}.logout-item{color:#c53030!important;font-weight:700;letter-spacing:.5px}.logout-item:hover{background-color:#ffe5e5;color:#a81c1c!important}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width: 768px){.user-dropdown-menu{right:0;left:0;min-width:100vw;border-radius:0 0 18px 18px;margin-top:0;box-shadow:0 6px 24px #0000001a;padding-bottom:1rem}.dropdown-header{padding:1rem 1.5rem;font-size:1.05rem}.dropdown-item{font-size:1.05rem;padding:1rem 1.5rem}.user-name{display:none}.user-dropdown-toggle{padding:.5rem}}.navbar{position:sticky;top:1rem;background-color:#2d3748;box-shadow:0 4px 12px #0006;z-index:1000;padding:1rem 2rem;margin:0 2rem;border-radius:1rem;border:1px solid #4a5568;display:flex;justify-content:space-between;align-items:center}.navbar-logo{flex-shrink:0;display:flex;align-items:center}.logo-image{height:50px;width:auto;transition:all .3s ease}.logo-image:hover{transform:scale(1.05);opacity:.9}.logo-text{font-family:Courier New,monospace;font-size:1.3rem;font-weight:700;color:#63b3ed;letter-spacing:.05em;text-shadow:0 0 8px rgba(99,179,237,.3)}.logo-text.fallback{display:inline}.desktop-logo{display:flex}.mobile-logo{display:none;cursor:pointer;align-items:center;gap:.5rem;padding:.5rem;border-radius:8px;transition:all .2s ease;-webkit-user-select:none;user-select:none}.mobile-logo:hover{background-color:#ffffff1a}.menu-indicator{display:flex;align-items:center;color:#e2e8f0;transition:transform .3s ease}.menu-indicator.open{transform:rotate(180deg)}.nav-list{display:flex;align-items:center;gap:1rem;list-style:none;margin:0;padding:0}.desktop-nav{display:flex}.nav-separator{width:1px;height:24px;background-color:#4a5568;margin:0 .5rem}.nav-social{display:flex!important;align-items:center;justify-content:center;width:40px;height:40px;border-radius:8px;transition:all .2s ease;color:#e2e8f0}.nav-social:hover{background-color:#ffffff1a;transform:translateY(-2px);color:#63b3ed}.nav-action{display:flex!important;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;font-weight:500;font-size:.9rem;transition:all .2s ease;text-decoration:none!important}.cv-download{background:linear-gradient(135deg,#e53e3e,#c53030);color:#fff!important;border:none}.cv-download:hover{background:linear-gradient(135deg,#c53030,#9c2626);transform:translateY(-2px);box-shadow:0 4px 12px #e53e3e66}.cv-download.compact{padding:.4rem .7rem;font-size:.8rem;gap:.4rem}.contact-btn{background:linear-gradient(135deg,#4a5568,#2d3748);color:#fff!important;border:none;cursor:pointer;font-family:inherit}.contact-btn:hover{background:linear-gradient(135deg,#2d3748,#1a202c);transform:translateY(-2px);box-shadow:0 4px 12px #4a556866}.nav-user{margin-left:.5rem}.mobile-menu{position:absolute;top:100%;left:0;right:0;background:#2d3748;border:1px solid #4a5568;border-top:none;border-radius:0 0 1rem 1rem;transform:translateY(-10px);opacity:0;visibility:hidden;transition:all .3s ease;max-height:70vh;overflow-y:auto;box-shadow:0 8px 25px #0000004d;z-index:1001}.mobile-menu.open{transform:translateY(0);opacity:1;visibility:visible}.mobile-menu-content{padding:1.5rem}.mobile-section{margin-bottom:2rem}.mobile-section:last-child{margin-bottom:0}.language-switcher-container{display:flex;align-items:center}.mobile-language-switcher{display:flex;justify-content:center;padding:10px 0}.mobile-section-title{font-size:.9rem;font-weight:600;color:#63b3ed;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.05em}.mobile-social-links{display:flex;flex-direction:column;gap:.75rem}.mobile-social-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background:#ffffff0d;border-radius:8px;color:#e2e8f0;text-decoration:none;transition:all .2s ease;position:relative;z-index:1002}.mobile-social-item:hover{background:#ffffff1a;color:#63b3ed;transform:translate(4px)}.mobile-actions{display:flex;flex-direction:column;gap:.75rem}.mobile-action-item{display:flex;align-items:center;gap:1rem;padding:.75rem;border-radius:8px;color:#fff;text-decoration:none;font-weight:500;transition:all .2s ease;border:none;font-family:inherit;font-size:1rem;cursor:pointer;width:100%;text-align:left;position:relative;z-index:1002}.cv-item{background:linear-gradient(135deg,#e53e3e,#c53030)}.cv-item:hover{background:linear-gradient(135deg,#c53030,#9c2626);transform:translate(4px)}.contact-item{background:linear-gradient(135deg,#4a5568,#2d3748)}.contact-item:hover{background:linear-gradient(135deg,#2d3748,#1a202c);transform:translate(4px)}.mobile-user{padding:.75rem;background:#ffffff0d;border-radius:8px;position:relative;z-index:1002}.mobile-menu-overlay{position:fixed;inset:0;background:#0000004d;z-index:998;pointer-events:auto}@media (max-width: 1024px){.navbar{padding:.75rem 1.5rem}.nav-list{gap:.8rem}.logo-image{height:45px}.logo-text{font-size:1.1rem}}@media (max-width: 768px){.navbar{margin:0 1rem;padding:1rem;border-radius:1rem;flex-direction:row;justify-content:center;align-items:center;position:relative}.desktop-logo,.desktop-nav{display:none!important}.mobile-logo{display:flex!important;align-items:center;justify-content:center;position:relative;z-index:1003}.logo-image{height:40px}}@media (max-width: 480px){.navbar{margin:0 .5rem;padding:.75rem}.logo-image{height:36px}.mobile-menu-content{padding:1rem}.mobile-section{margin-bottom:1.5rem}.mobile-action-item{padding:.6rem;font-size:.9rem}.mobile-social-item{padding:.6rem}}@media (max-width: 320px){.navbar{margin:0 .25rem;padding:.5rem}.logo-image{height:32px}.menu-indicator svg{width:10px;height:10px}}.language-switch{display:flex;align-items:center;gap:6px;font-weight:500;color:#e2e8f0;font-size:.85rem}.language-switch .lang-label{font-size:.82em;letter-spacing:.5px;opacity:.85;font-weight:400;padding:0 2px;-webkit-user-select:none;user-select:none;transition:color .2s}.switch{position:relative;display:inline-block;width:34px;height:18px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#444;transition:.3s;border-radius:18px}.slider:before{position:absolute;content:"";height:13px;width:13px;left:3px;bottom:2.5px;background-color:#fff;transition:.3s;border-radius:50%;box-shadow:0 1px 4px #0002}input:checked+.slider{background-color:#3182ce}input:checked+.slider:before{transform:translate(15px)}.switch:hover .slider{background-color:#555}.navbar{position:sticky;top:1rem;background-color:#2d3748;box-shadow:0 4px 12px #0006;z-index:1000;padding:1rem 2rem;margin:0 2rem;border-radius:1rem;border:1px solid #4a5568}.nav-list{display:flex;justify-content:center;gap:2rem;list-style:none}.nav-list a{text-decoration:none;color:#e2e8f0;font-weight:600;font-size:1rem;transition:color .3s ease}.nav-list a:hover{color:#63b3ed}.hero{padding:0;background:none;border-radius:1rem;margin:2rem;display:flex;align-items:stretch;gap:0;min-height:400px;box-shadow:0 4px 12px #0000004d;overflow:hidden}.right-subtitle{font-size:1.8rem;font-weight:600;color:#63b3ed;margin-top:-.5rem;margin-bottom:1.5rem;line-height:1.3;display:flex;justify-content:center;align-items:center;text-align:center}.hero-location{font-size:.85rem;color:#e2e8f0;letter-spacing:.02em;opacity:.85;margin:0}.hero-left{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;background-color:#131212;padding:3rem 2rem;border-radius:1rem 0 0 1rem}.hero-right{flex:2;display:flex;flex-direction:column;justify-content:center;text-align:left;background:linear-gradient(135deg,#2d3748,#4a5568);padding:3rem 2rem;border-radius:0 1rem 1rem 0}.profile-photo{width:200px;height:200px;border-radius:50%;object-fit:cover;margin-bottom:1.5rem;border:4px solid #2d3748;box-shadow:0 4px 8px #0003}.hero-title{font-size:1.5rem;font-weight:700;margin:.5rem 0;color:#fff}.hero-subtitle{font-size:1.1rem;color:#4a5568;margin-bottom:.5rem;text-align:center;display:flex;align-items:center;justify-content:center;gap:.5rem}.hero-subtitle svg{flex-shrink:0}.hero-description{font-size:1.2rem;color:#e2e8f0;line-height:1.6;margin-bottom:2.5rem}.social-links{display:flex;gap:1.5rem;justify-content:center;margin-top:2rem}.social-links img{width:32px;height:32px;transition:transform .3s ease;filter:brightness(0) invert(1)}.social-links img:hover{transform:scale(1.2);filter:brightness(0) invert(1) sepia(1) saturate(5) hue-rotate(180deg)}.nav-user{margin-left:auto}.nav-login{display:flex!important;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fff!important;text-decoration:none;transition:all .2s ease;font-weight:500}.nav-login:hover{background:#ffffff26;transform:translateY(-1px)}@media (max-width: 768px){.navbar{margin:0 1rem;padding:.75rem 1rem;border-radius:.75rem}.hero{flex-direction:column;gap:0;margin:1rem}.hero-left{border-radius:1rem 1rem 0 0;padding:2rem 1rem}.hero-right{border-radius:0 0 1rem 1rem;text-align:center;padding:2rem 1rem}.hero-title{font-size:1.8rem}.hero-description{font-size:1.1rem}}#about{padding:0 0 3rem}#about .section-title{text-align:center;margin-bottom:1.5rem;margin-top:0}#about .card{background-color:transparent!important;border:none!important;box-shadow:none!important;padding:0!important;border-radius:0!important;max-width:900px;margin:0 auto}#about .card:hover{transform:none!important;background-color:transparent!important}section#about .card p{color:#cbd5e0!important;font-size:1.1rem!important;line-height:1.8!important;margin-bottom:2rem!important;text-align:left!important;text-indent:0!important;font-weight:400!important;-webkit-hyphens:auto;hyphens:auto}section#about .card p:first-child{text-indent:0!important;font-size:1.15rem!important;font-weight:500!important;color:#e2e8f0!important;text-align:left!important;margin-bottom:2.5rem!important}section#about .card p:last-of-type{margin-bottom:2.5rem!important}#about .social-links{display:flex;justify-content:center;gap:1.5rem;margin-top:2rem;padding-top:2rem;border-top:1px solid #4a5568}#about .social-links a{display:flex;align-items:center;justify-content:center;width:50px;height:50px;background:linear-gradient(135deg,#4a5568,#2d3748);border-radius:12px;transition:all .3s ease;border:1px solid #4a5568;box-shadow:0 4px 12px #0000004d}#about .social-links a:hover{background:linear-gradient(135deg,#63b3ed,#4299e1);border-color:#63b3ed;transform:translateY(-3px);box-shadow:0 8px 25px #63b3ed66}#about .social-links img{width:24px;height:24px;transition:all .3s ease}#about .social-links a[href*=github] img{filter:invert(1)}#about .social-links a[href*=github]:hover img{filter:invert(1) brightness(1.2);transform:scale(1.1)}#about .social-links a[href*=linkedin] img{filter:none}#about .social-links a[href*=linkedin]:hover img{filter:brightness(1.2) saturate(1.3);transform:scale(1.1)}@media (max-width: 1024px){#about .card{max-width:800px;padding:0 1rem!important}section#about .card p{font-size:1.05rem!important;line-height:1.7!important;text-indent:0!important;text-align:left!important}section#about .card p:first-child{font-size:1.1rem!important;text-align:left!important}}@media (max-width: 768px){#about{padding:0 0 3rem}#about .card{max-width:100%;padding:0!important}section#about .card p{font-size:1rem!important;line-height:1.6!important;text-align:left!important;text-indent:0!important;margin-bottom:1.5rem!important}section#about .card p:first-child{font-size:1.05rem!important;text-align:left!important;margin-bottom:2rem!important}#about .social-links{gap:1rem;margin-top:1.5rem;padding-top:1.5rem}#about .social-links a{width:45px;height:45px}#about .social-links img{width:22px;height:22px}}@media (max-width: 480px){#about .section-title{font-size:1.8rem;margin-bottom:2rem;margin-top:0}section#about .card p{font-size:.95rem!important;line-height:1.5!important;margin-bottom:1.25rem!important;text-align:left!important}section#about .card p:first-child{font-size:1rem!important;margin-bottom:1.5rem!important;text-align:left!important}#about .social-links{gap:.8rem}#about .social-links a{width:42px;height:42px}#about .social-links img{width:20px;height:20px}}.certificate-card{cursor:pointer;transition:box-shadow .2s,transform .2s;position:relative}.certificate-card:hover,.certificate-card:focus{box-shadow:0 0 0 3px #63b3ed55;transform:translateY(-2px) scale(1.02);outline:none}.certificate-card .cert-view-link{display:inline-block;margin-top:.5rem;color:#63b3ed;font-size:.95rem;font-weight:600;background:#232b3b;border-radius:.5rem;padding:.2rem .7rem;transition:background .2s}.certificate-card .cert-view-link:hover{background:#63b3ed22}.certificate-card.expanded{max-width:900px;margin:2.5rem auto;padding:2.5rem 2rem;text-align:center;cursor:default;box-shadow:0 8px 40px #0006;z-index:10;position:relative;min-height:400px;animation:cert-expand .45s cubic-bezier(.4,.2,.2,1);opacity:1;transform:scale(1)}@keyframes cert-expand{0%{opacity:0;transform:scale(.85) translateY(40px)}60%{opacity:1;transform:scale(1.04) translateY(-8px)}to{opacity:1;transform:scale(1) translateY(0)}}.cert-back-row{width:100%;display:flex;justify-content:flex-start;margin-bottom:1rem}.cert-back-btn{background:#232b3b;color:#63b3ed;border:none;border-radius:.5rem;font-size:.95rem;padding:.25rem .8rem;cursor:pointer;box-shadow:0 2px 8px #0002;transition:background .2s,transform .2s;z-index:2;display:inline-flex;align-items:center;gap:.5rem;min-width:unset;min-height:unset}.cert-back-btn:hover,.cert-back-btn:focus{background:#63b3ed22;outline:none;transform:scale(1.05)}.cert-file-viewer{display:block;margin:2rem auto 0;max-width:100%;max-height:70vh;border-radius:.5rem;box-shadow:0 2px 16px #0003;background:#fff}.cert-no-file{color:#f56565;margin-top:2rem;font-weight:600}.certificate-card.leaving{opacity:0;transform:scale(.95) translateY(30px);transition:opacity .25s,transform .25s;pointer-events:none}@media (max-width: 1024px){.certificate-card.expanded{max-width:98vw;padding:1.5rem .5rem;min-height:250px}.cert-file-viewer{max-height:50vh}}@media (max-width: 768px){.certificate-card.expanded{padding:1rem .2rem;margin:1rem 0;max-width:100vw;min-height:180px}.cert-file-viewer{max-height:40vh}.cert-back-row{justify-content:center;margin-bottom:.7rem}.cert-back-btn{width:90%;font-size:.95rem;padding:.3rem 0;border-radius:.5rem;justify-content:center}}.tab-container{width:100%;min-height:70vh;margin:2rem auto;max-width:calc(100% - 1rem);background-color:#2d3748;border-radius:1rem;box-shadow:0 4px 12px #0000004d;border:1px solid #4a5568;overflow:hidden}.tab-navigation{background-color:#374151;padding:1.5rem 2rem 0;border-bottom:1px solid #4a5568;position:relative}.desktop-tabs{display:flex;gap:0;justify-content:center;flex-wrap:wrap;margin-bottom:-1px}.tab-button{padding:1rem 2rem;background-color:transparent;border:none;border-bottom:3px solid transparent;color:#a0aec0;cursor:pointer;font-weight:600;font-size:.95rem;transition:all .3s ease;white-space:nowrap;position:relative}.tab-button:hover{background-color:#63b3ed1a;color:#63b3ed;border-bottom-color:#63b3ed}.tab-button.active{background-color:transparent;color:#63b3ed;border-bottom-color:#63b3ed;position:relative}.mobile-dropdown{display:none;position:relative;margin-bottom:1rem}.dropdown-toggle{width:100%;padding:1rem 1.5rem;background-color:#4a5568;border:1px solid #63b3ed;border-radius:.5rem;color:#e2e8f0;font-weight:600;font-size:1rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:all .3s ease}.dropdown-toggle:hover{background-color:#63b3ed;color:#1a202c}.dropdown-arrow{transition:transform .3s ease;color:#63b3ed}.dropdown-toggle:hover .dropdown-arrow{color:#1a202c}.dropdown-arrow.open{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:100%;left:0;right:0;background-color:#2d3748;border:1px solid #4a5568;border-radius:.5rem;box-shadow:0 8px 25px #0006;z-index:1000;margin-top:.5rem;overflow:hidden;animation:dropdownSlide .2s ease-out}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{width:100%;padding:1rem 1.5rem;background-color:transparent;border:none;color:#cbd5e0;font-weight:500;font-size:.95rem;cursor:pointer;text-align:left;transition:all .2s ease;border-bottom:1px solid #4a5568}.dropdown-item:last-child{border-bottom:none}.dropdown-item:hover{background-color:#374151;color:#63b3ed}.dropdown-item.active{background-color:#63b3ed;color:#1a202c;font-weight:600}.tab-content{background-color:#2d3748;min-height:500px;flex:1}.content-wrapper{padding:2.5rem;animation:fadeIn .4s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.content-wrapper .section{padding:0;margin:0}.content-wrapper .section-title{color:#63b3ed;margin-bottom:2rem;text-align:center}.content-wrapper .section-title:after{left:50%;transform:translate(-50%)}.fade-animate{animation:fadeInTab .5s cubic-bezier(.4,2,.6,1)}@keyframes fadeInTab{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.slide-animate{animation:slideInTab .8s cubic-bezier(.4,1.5,.6,1);will-change:transform,opacity}@keyframes slideInTab{0%{opacity:0;transform:translate(80px) scale(.97)}to{opacity:1;transform:translate(0) scale(1)}}@media (max-width: 768px){.tab-container{margin:1rem auto;max-width:calc(100% - .5rem)}.tab-navigation{padding:1rem}.desktop-tabs{display:none}.mobile-dropdown{display:block}.content-wrapper{padding:1.5rem}}@media (max-width: 480px){.tab-navigation{padding:.75rem}.content-wrapper{padding:1rem}.dropdown-toggle,.dropdown-item{padding:.875rem 1.25rem;font-size:.9rem}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem;font-family:Arial,sans-serif}.login-wrapper{width:100%;max-width:400px}.login-card{background:#fff;border-radius:16px;box-shadow:0 20px 40px #0000001a;padding:2.5rem;animation:slideUp .6s ease-out}.login-header{text-align:center;margin-bottom:2rem}.login-title{font-size:1.75rem;font-weight:700;color:#2d3748;margin:0 0 .5rem}.login-subtitle{color:#718096;margin:0;font-size:.95rem}.login-form,.form-group{margin-bottom:1.5rem}.form-label{display:block;margin-bottom:.5rem;font-weight:600;color:#2d3748;font-size:.9rem}.form-input{width:100%;padding:.875rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:all .3s ease;background:#f7fafc;box-sizing:border-box}.form-input:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 3px #667eea1a}.form-input:disabled{background:#f7fafc;cursor:not-allowed;opacity:.6}.form-input::placeholder{color:#a0aec0}.login-button{width:100%;padding:.875rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.login-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 20px #667eea4d}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.7;cursor:not-allowed;transform:none;box-shadow:none}.loading-spinner{animation:spin 1s linear infinite}.login-footer{text-align:center;border-top:1px solid #e2e8f0;padding-top:1.5rem}.back-link{margin:0 0 1rem}.back-to-portfolio{color:#667eea;text-decoration:none;font-weight:500;transition:color .3s ease}.back-to-portfolio:hover{color:#764ba2;text-decoration:underline}.login-info{margin:0}.login-info small{color:#a0aec0;font-size:.8rem}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 480px){.login-container{padding:.5rem}.login-card{padding:2rem 1.5rem}.login-title{font-size:1.5rem}}.error-message{display:flex;align-items:center;gap:.5rem;background:#fed7d7;color:#c53030;padding:.75rem 1rem;border-radius:8px;margin-bottom:1.5rem;border:1px solid #feb2b2;font-size:.9rem}.error-message svg{flex-shrink:0}.admin-container{min-height:100vh;background:#f8fafc;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.admin-header{background:#fff;border-bottom:1px solid #e2e8f0;padding:1rem 2rem;position:sticky;top:0;z-index:100;box-shadow:0 1px 3px #0000001a}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto}.header-main-info{display:flex;flex-direction:column;gap:.25rem}.admin-title{margin:0;color:#1a202c;font-size:1.5rem;font-weight:600}.header-info{display:flex;align-items:center;gap:1rem;font-size:.9rem}.welcome-text{color:#4a5568;font-weight:500}.header-actions{display:flex;align-items:center;gap:1rem}.message-count{background:#667eea;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:500}.back-button{display:flex;align-items:center;gap:.5rem;color:#667eea;text-decoration:none;padding:.5rem 1rem;border:1px solid #667eea;border-radius:6px;font-weight:500;transition:all .2s ease}.back-button:hover{background:#667eea;color:#fff;transform:translateY(-1px)}.admin-content{display:grid;grid-template-columns:400px 1fr;height:calc(100vh - 80px);max-width:1400px;margin:0 auto}.messages-sidebar{background:#fff;border-right:1px solid #e2e8f0;display:flex;flex-direction:column}.sidebar-header{padding:1.5rem;border-bottom:1px solid #e2e8f0}.sidebar-header h2{margin:0;color:#2d3748;font-size:1.1rem;font-weight:600}.messages-list{flex:1;overflow-y:auto}.message-item{padding:1rem 1.5rem;border-bottom:1px solid #f1f5f9;cursor:pointer;transition:all .2s ease}.message-item:hover{background:#f8fafc}.message-item.selected{background:#eef2ff;border-right:3px solid #667eea}.message-item-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.message-name{margin:0;font-size:.95rem;font-weight:600;color:#1a202c}.message-date{font-size:.75rem;color:#718096}.message-email{margin:0 0 .5rem;font-size:.85rem;color:#667eea}.message-preview{margin:0;font-size:.85rem;color:#4a5568;line-height:1.4}.message-detail{background:#fff;display:flex;flex-direction:column}.detail-content{padding:2rem;height:100%;display:flex;flex-direction:column}.detail-header{border-bottom:1px solid #e2e8f0;padding-bottom:1.5rem;margin-bottom:1.5rem}.sender-info{margin-bottom:1rem}.sender-name{margin:0 0 .5rem;color:#1a202c;font-size:1.5rem;font-weight:600}.sender-email{color:#667eea;text-decoration:none;font-weight:500}.sender-email:hover{text-decoration:underline}.message-meta{display:flex;gap:1rem;font-size:.875rem;color:#718096}.detail-body{flex:1}.detail-body h3{margin:0 0 1rem;color:#2d3748;font-size:1.1rem}.message-content{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1.5rem;font-size:1rem;line-height:1.6;color:#2d3748;white-space:pre-wrap}.detail-actions{display:flex;gap:1rem;padding-top:1.5rem;border-top:1px solid #e2e8f0}.action-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:6px;font-weight:500;cursor:pointer;text-decoration:none;transition:all .2s ease}.reply-button{background:#667eea;color:#fff}.reply-button:hover{background:#5a67d8;transform:translateY(-1px)}.delete-button{background:#e53e3e;color:#fff}.delete-button:hover{background:#c53030;transform:translateY(-1px)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;color:#718096}.loading-spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top:3px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.no-messages,.no-selection{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#718096;text-align:center;padding:2rem}.no-messages-icon,.no-selection-icon{margin-bottom:1rem;opacity:.5}.no-selection h3{margin:0 0 .5rem;color:#4a5568}.no-selection p{margin:0;color:#718096}@media (max-width: 768px){.admin-content{grid-template-columns:1fr;grid-template-rows:300px 1fr}.header-content{flex-direction:column;gap:1rem;text-align:center}.admin-header,.detail-content{padding:1rem}.detail-actions{flex-direction:column}}@media (max-width: 480px){.message-item{padding:.75rem 1rem}.message-item-header{flex-direction:column;align-items:flex-start;gap:.25rem}}.protected-loading-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:#f8fafc;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.protected-loading-content{display:flex;flex-direction:column;align-items:center;gap:1rem;color:#718096}.loading-spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top:3px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}.access-denied-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:#f8fafc;padding:2rem;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.access-denied-content{text-align:center;background:#fff;padding:3rem 2rem;border-radius:16px;box-shadow:0 10px 40px #0000001a;border:1px solid #e2e8f0;max-width:450px;width:100%}.access-denied-icon{color:#e53e3e;margin-bottom:1.5rem}.access-denied-content h2{color:#1a202c;margin:0 0 1rem;font-size:1.5rem;font-weight:600}.access-denied-content p{color:#718096;margin:0 0 2rem;line-height:1.6;font-size:1rem}.access-denied-actions{display:flex;justify-content:center}.back-home-link{display:inline-flex;align-items:center;gap:.5rem;color:#667eea;text-decoration:none;font-weight:500;padding:.75rem 1.5rem;border:1px solid #667eea;border-radius:8px;transition:all .2s ease;background:#fff}.back-home-link:hover{background:#667eea;color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 480px){.access-denied-container{padding:1rem}.access-denied-content{padding:2rem 1.5rem}.access-denied-content h2{font-size:1.25rem}}
