body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box;margin:0;padding:0}::-webkit-scrollbar{display:none;height:0;width:0}*{-ms-overflow-style:none;scrollbar-width:none}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;overflow-y:scroll}.App,body{overflow-x:hidden}.App{background:linear-gradient(135deg,#a8e6cf,#dcedc1 50%,#ffd3b6);min-height:100vh;position:relative}.background-overlay{backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);z-index:0}.App:before,.background-overlay{bottom:0;left:0;pointer-events:none;position:fixed;right:0;top:0}.App:before{animation:bgFloat 20s ease-in-out infinite;background:radial-gradient(circle at 20% 50%,#fff3 0,#0000 50%),radial-gradient(circle at 80% 80%,#fff3 0,#0000 50%);content:""}@keyframes bgFloat{0%,to{opacity:1;transform:translateY(0)}50%{opacity:.8;transform:translateY(-20px)}}.container{margin:0 auto;max-width:1200px;padding:30px 20px;position:relative;z-index:1}.loading-container{align-items:center;color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:100vh}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:50px;width:50px}@keyframes spin{to{transform:rotate(1turn)}}.loading-container p{font-size:18px;margin-top:20px}.error-container{align-items:center;color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:20px;text-align:center}.error-container h2{font-size:32px;margin-bottom:16px}.error-container p{font-size:18px;margin-bottom:12px}.error-hint{background:#ffffff1a;border-radius:8px;margin-top:20px;padding:12px 24px}.footer{color:#fffc;font-size:14px;padding:20px;position:relative;text-align:center;z-index:1}@media (max-width:768px){.container{padding:20px 15px}.error-container h2{font-size:24px}.error-container p{font-size:16px}}.profile-section{margin-bottom:40px}.profile-card{animation:fadeInUp .8s ease-out;background:#0000;border-radius:24px;box-shadow:none;overflow:hidden;padding:40px 30px;position:relative;text-align:center}.profile-avatar-container{display:inline-block;margin-bottom:20px;position:relative}.profile-avatar{animation:avatarPulse 3s ease-in-out infinite;border:5px solid #fff;border-radius:50%;box-shadow:0 10px 30px #0003;height:120px;object-fit:cover;position:relative;width:120px;z-index:1}@keyframes avatarPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.avatar-ring{animation:ringPulse 3s ease-in-out infinite;background:linear-gradient(135deg,#52b788,#95d5b2);border-radius:50%;bottom:-10px;left:-10px;opacity:.3;position:absolute;right:-10px;top:-10px}@keyframes ringPulse{0%,to{opacity:.3;transform:scale(1)}50%{opacity:.5;transform:scale(1.1)}}.profile-nickname{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#52b788,#95d5b2);-webkit-background-clip:text;background-clip:text;color:#2d3748;font-size:36px;font-weight:700;margin-bottom:12px;text-shadow:0 2px 4px #0000001a}.profile-position{margin-bottom:24px}.position-badge{background:linear-gradient(135deg,#52b788,#95d5b2);border-radius:20px;box-shadow:0 4px 15px #52b78866;color:#fff;display:inline-block;font-size:14px;font-weight:600;letter-spacing:.5px;padding:8px 24px}.profile-introduction{color:#2d3748;font-size:16px;font-weight:500;line-height:1.6;margin-bottom:0;margin-left:auto;margin-right:auto;max-width:600px;text-shadow:0 1px 3px #fffc}.profile-motto{align-items:center;background:linear-gradient(135deg,#52b7881a,#95d5b21a);border-radius:12px;display:flex;gap:12px;justify-content:center;margin-left:auto;margin-right:auto;margin-top:24px;max-width:500px;padding:16px 24px}.motto-icon{font-size:24px}.motto-text{color:#2d6a4f;font-size:16px;font-style:italic;font-weight:500}@media (max-width:768px){.profile-card{padding:30px 20px}.profile-avatar{height:100px;width:100px}.profile-nickname{font-size:28px}.profile-introduction{font-size:15px}.profile-motto{flex-direction:column;gap:8px}}.techstack-section{animation:fadeInUp .8s ease-out .15s both;background:#ffffff0d;border:2px solid #52b7884d;border-radius:20px;box-shadow:0 4px 20px #52b7881a;margin-bottom:40px;padding:24px}.techstack-container{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:16px;box-shadow:0 8px 32px #0000001a;padding:24px}.tech-items{grid-gap:12px;align-items:center;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));justify-items:center}.tech-item{backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);background:#ffffff26;border:1px solid #ffffff40;border-radius:12px;cursor:pointer;display:flex;justify-content:center;padding:12px;transition:all .3s ease;width:100%}.tech-item img{display:block;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));height:32px;max-width:100%;object-fit:contain;transition:transform .3s ease,filter .3s ease}.tech-item:hover{background:#ffffff40;box-shadow:0 4px 15px #52b78833;transform:translateY(-3px)}.tech-item:hover img{filter:brightness(1.1) drop-shadow(0 4px 8px rgba(0,0,0,.15))}@media (max-width:768px){.section-title{font-size:28px}.techstack-container{padding:20px}.tech-items{gap:10px;grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}.tech-item img{height:28px}}.projects-section{animation:fadeInUp .8s ease-out .2s both;background:#ffffff0d;border:2px solid #52b7884d;border-radius:20px;box-shadow:0 4px 20px #52b7881a;margin-bottom:40px;padding:24px}.title-icon{animation:bounce 2s ease-in-out infinite;display:inline-block;font-size:36px}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.projects-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(5,1fr)}.project-card{background:#fffffff2;border-radius:12px;box-shadow:0 2px 12px #00000014;color:inherit;display:flex;flex-direction:column;overflow:hidden;padding:20px;position:relative;text-decoration:none;transition:all .3s ease}.develop-badge{color:#52b788;cursor:help;opacity:.85;position:absolute;right:10px;top:10px;transition:opacity .2s ease;z-index:10}.develop-badge:hover{opacity:1}.develop-badge svg{display:block;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.project-card:before{background:linear-gradient(90deg,#52b788,#95d5b2);content:"";height:3px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .3s ease}.project-card:hover:before{transform:scaleX(1)}.project-card:hover{box-shadow:0 8px 25px #0000001f;transform:translateY(-5px)}.project-header{align-items:center;display:flex;gap:12px;margin-bottom:12px}.project-icon{border-radius:8px;box-shadow:0 2px 8px #0000001a;flex-shrink:0;height:40px;overflow:hidden;width:40px}.project-icon img{height:100%;object-fit:cover;width:100%}.project-title{color:#2d3748;flex:1 1;font-size:18px;font-weight:700;margin:0}.project-description{color:#4a5568;flex-grow:1;font-size:14px;line-height:1.5;margin-bottom:12px}.project-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.project-tag{background:linear-gradient(135deg,#52b78826,#95d5b226);border-radius:10px;color:#2d6a4f;display:inline-block;font-size:12px;font-weight:500;padding:3px 10px}.project-link-indicator{align-items:center;border-top:1px solid #e2e8f0;color:#52b788;display:flex;font-size:13px;font-weight:600;justify-content:space-between;padding-top:12px}.arrow{font-size:18px;transition:transform .3s ease}.project-card:hover .arrow{transform:translateX(4px)}@media (max-width:768px){.projects-grid{gap:12px;grid-template-columns:repeat(2,1fr)}.section-title{font-size:28px}.project-card{padding:16px}.develop-badge{right:8px;top:8px}.develop-badge svg{height:16px;width:16px}.project-header{gap:10px;margin-bottom:10px}.project-icon{height:36px;width:36px}.project-title{font-size:16px}.project-description{font-size:13px}.project-tag{font-size:11px;padding:2px 8px}}@media (min-width:769px) and (max-width:1024px){.projects-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width:1025px) and (max-width:1440px){.projects-grid{grid-template-columns:repeat(4,1fr)}}.contacts-section{animation:fadeInUp .8s ease-out .4s both;background:#ffffff0d;border:2px solid #52b7884d;border-radius:20px;box-shadow:0 4px 20px #52b7881a;margin-bottom:40px;padding:24px}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.section-title{align-items:center;color:#fff;display:flex;font-size:32px;font-weight:700;gap:12px;margin-bottom:20px}.title-icon{font-size:32px}.contacts-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr)}.contact-card{align-items:center;background:#fffffff2;border-radius:16px;box-shadow:0 4px 20px #0000001a;display:flex;gap:16px;padding:20px;position:relative;transition:all .3s ease}.contact-card:hover{box-shadow:0 8px 30px #00000026;transform:translateY(-4px)}.contact-icon{align-items:center;background:linear-gradient(135deg,#52b788,#95d5b2);border-radius:10px;box-shadow:0 4px 12px #52b7884d;display:flex;flex-shrink:0;font-size:28px;height:48px;justify-content:center;overflow:hidden;position:relative;width:48px}.contact-icon-img{border-radius:10px;height:100%;object-fit:cover;width:100%}.contact-icon-emoji{font-size:28px;line-height:1}.contact-info{flex-grow:1;min-width:0}.contact-label{color:#2d3748;font-size:15px;font-weight:600;margin-bottom:4px}.contact-value{color:#4a5568;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.contact-actions{display:flex;flex-shrink:0;gap:6px}.contact-button{align-items:center;background:#52b7881a;border:none;border-radius:8px;color:#52b788;cursor:pointer;display:flex;font-size:16px;height:32px;justify-content:center;text-decoration:none;transition:all .2s ease;width:32px}.contact-button:hover{background:linear-gradient(135deg,#52b788,#95d5b2);color:#fff;transform:scale(1.1)}.contact-button:active{transform:scale(.95)}.copy-toast{animation:toastSlideIn .3s ease-out;background:#48bb78;border-radius:8px;box-shadow:0 4px 12px #48bb7866;color:#fff;font-size:13px;font-weight:600;padding:6px 12px;position:absolute;right:20px;top:-36px}@keyframes toastSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.contacts-grid{gap:12px;grid-template-columns:1fr}.section-title{font-size:24px;margin-bottom:20px}.contact-card{border-radius:12px;gap:12px;padding:14px}.contact-icon{font-size:22px;height:40px;width:40px}.contact-icon,.contact-icon-img{border-radius:8px}.contact-icon-emoji{font-size:22px}.contact-label{font-size:14px}.contact-value{font-size:12px}.contact-actions{gap:6px}.contact-button{font-size:14px;height:28px;width:28px}.copy-toast{right:50%;transform:translateX(50%)}}@media (min-width:769px) and (max-width:1024px){.contacts-grid{grid-template-columns:repeat(3,1fr)}}.click-particle{animation-fill-mode:forwards;animation-name:particle-radiate;animation-timing-function:ease-out;border-radius:50%;box-shadow:0 0 8px #ffffffe6;mix-blend-mode:screen;pointer-events:none;position:fixed;transform:translate(-50%,-50%);will-change:transform,opacity;z-index:9999}@keyframes particle-radiate{0%{opacity:1;transform:translate(-50%,-50%) scale(1)}25%{opacity:.9;transform:translate(calc(-50% + var(--target-x)*.3),calc(-50% + var(--target-y)*.3)) scale(1.2)}to{opacity:0;transform:translate(calc(-50% + var(--target-x)),calc(-50% + var(--target-y))) scale(0)}}.click-burst{animation:burst-effect .6s ease-out forwards;background:radial-gradient(circle,#fffc 0,#fff6 30%,#fff0 70%);border-radius:50%;height:20px;pointer-events:none;position:fixed;transform:translate(-50%,-50%);width:20px;z-index:9998}@keyframes burst-effect{0%{opacity:1;transform:translate(-50%,-50%) scale(0)}50%{opacity:.6;transform:translate(-50%,-50%) scale(2)}to{opacity:0;transform:translate(-50%,-50%) scale(3)}}
/*# sourceMappingURL=main.e473ef61.css.map*/