@import'https://fonts.googleapis.com/css2?family=Francois+One&family=Fira+Mono:wght@400;500;700&拼写: "Fira Mono" &family=Poppins:wght@300;400;500;700&display=swap';@import"https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.1.1/css/all.min.css";@import"https://fonts.googleapis.com/css2?family=Lato:wght@400;700&family=Montserrat:wght@700&display=swap";@import"https://fonts.googleapis.com/css2?family=Oswald:wght@700&display=swap";/*! tailwindcss v4.1.7 | MIT License | https://tailwindcss.com */@layer properties{@supports ((-webkit-hyphens:none) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}.visible{visibility:visible}.static{position:static}.block{display:block}.flex{display:flex}.hidden{display:none}.inline{display:inline}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.flex-wrap{flex-wrap:wrap}.border{border-style:var(--tw-border-style);border-width:1px}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,visibility,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}:root{color-scheme:light;background-color:#f5f5f5;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;font-weight:400;line-height:1.5}body{width:100%;min-width:320px;min-height:100vh;margin:0;padding:0;overflow-x:hidden}#root{width:100%;max-width:100%;margin:0;padding:0}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}.gooey-nav-container{position:relative;padding:.5rem;border-radius:100vw;display:inline-block;transition:background-color .3s ease;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.gooey-nav-container nav{display:flex;position:relative;transform:translateZ(.01px)}.gooey-nav-container nav ul{display:flex;gap:1.5em;list-style:none;padding:0 1em;margin:0;position:relative;z-index:3;text-shadow:0 1px 1px hsla(0,0%,0%,.2);transition:color .3s ease}.gooey-nav-container nav ul li{padding:.6em 1em;border-radius:100vw;position:relative;cursor:pointer;transition:background-color .3s ease,color .3s ease,box-shadow .3s ease;box-shadow:0 0 .5px 1.5px transparent}.gooey-nav-container nav ul li:focus-within:has(:focus-visible){box-shadow:0 0 .5px 1.5px currentColor}.gooey-nav-container nav ul li a{text-decoration:none;color:inherit}.gooey-nav-container .effect{position:absolute;left:0;top:0;width:0;height:0;opacity:1;pointer-events:none;display:grid;place-items:center;z-index:1}.gooey-nav-container .effect.text{transition:color .3s ease;display:flex;align-items:center;justify-content:center;font-size:1rem}.gooey-nav-container .effect.text.active{color:inherit}.gooey-nav-container .effect.filter{border-radius:100vw}.gooey-nav-container .effect.filter.active{animation:pill .3s ease both}@keyframes pill{to{transform:scale(1);opacity:1}}.particle,.point{display:block;opacity:0;width:20px;height:20px;border-radius:100%;transform-origin:center}.particle{--time: 5s;position:absolute;top:calc(50% - 10px);left:calc(50% - 10px);animation:particle calc(var(--time)) ease 1 -.35s}.point{opacity:1;animation:point calc(var(--time)) ease 1 -.35s}@keyframes particle{0%{transform:rotate(0) translate(calc(var(--start-x)),calc(var(--start-y)));opacity:1;animation-timing-function:cubic-bezier(.55,0,1,.45)}70%{transform:rotate(calc(var(--rotate) * .5)) translate(calc(var(--end-x) * 1.2),calc(var(--end-y) * 1.2));opacity:1;animation-timing-function:ease}85%{transform:rotate(calc(var(--rotate) * .66)) translate(calc(var(--end-x)),calc(var(--end-y)));opacity:1}to{transform:rotate(calc(var(--rotate) * 1.2)) translate(calc(var(--end-x) * .5),calc(var(--end-y) * .5));opacity:1}}@keyframes point{0%{transform:scale(0);opacity:0;animation-timing-function:cubic-bezier(.55,0,1,.45)}25%{transform:scale(calc(var(--scale) * .25))}38%{opacity:1}65%{transform:scale(var(--scale));opacity:1;animation-timing-function:ease}85%{transform:scale(var(--scale));opacity:1}to{transform:scale(0);opacity:0}}@media (max-width: 768px){.gooey-nav-container nav ul{gap:1rem}}.navbar{position:sticky;top:0;width:100%;padding:.5rem 0;z-index:10;transition:all .3s ease;left:0;right:0;box-sizing:border-box}.navbar-content{max-width:1200px;margin:0 auto;padding:0 1rem;display:flex;justify-content:space-between;align-items:center;height:3.5rem}.logo-container{flex:0 0 auto}.logo{display:flex;align-items:center;gap:.8rem;font-size:1.2rem;font-weight:700}.logo-path{transition:all .3s ease}.logo svg{transition:transform .3s ease}.logo:hover svg{transform:scale(1.1)}.logo-text{font-family:Poppins,Arial,sans-serif;font-size:1.5rem;white-space:nowrap}.logo-svg{width:3rem;height:3rem}.nav-links{display:none;align-items:center;height:100%}.nav-links-wrapper{flex:1;display:flex;justify-content:center}.mode-toggle{margin-left:.8rem;flex:0 0 auto}.mode-switch{background:none;border:none;font-size:1.3rem;cursor:pointer;padding:.5rem;border-radius:50%;transition:all .3s ease;display:flex;align-items:center;justify-content:center;min-height:44px}.mode-switch:hover{transform:rotate(15deg);background-color:#ffffff1a}.logout-button{padding:.5rem 1rem;border:none;border-radius:.4rem;font-weight:600;cursor:pointer;transition:all .3s ease;min-height:44px}.logout-button:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0003}.hamburger-menu{display:flex;background:none;border:none;cursor:pointer;padding:.5rem;z-index:100}.hamburger{width:24px;height:20px;position:relative;display:flex;flex-direction:column;justify-content:space-between}.hamburger span{display:block;width:100%;height:2px;background-color:currentColor;transition:all .3s ease}.hamburger.active span:nth-child(1){transform:translateY(9px) rotate(45deg)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:translateY(-9px) rotate(-45deg)}@media (min-width: 768px){.hamburger-menu{display:none}.nav-links{display:flex}.nav-links-wrapper{position:static;transform:none;background:none;padding:0;height:auto}}@media (max-width: 768px){.nav-links-wrapper{position:fixed;top:3.5rem;left:0;width:100%;height:calc(100vh - 3.5rem);background-color:inherit;transform:translate(100%);transition:transform .3s ease;padding:1.5rem;box-sizing:border-box}.nav-links-wrapper.active{transform:translate(0)}.nav-links{display:flex;flex-direction:column;align-items:center;gap:1.2rem}.mode-toggle{position:absolute;right:3rem}}@media (max-width: 480px){.navbar-content{padding:0 .5rem}.logo-text{font-size:1.3rem}.logo-svg{width:2.5rem;height:2.5rem}}.theme-button{position:fixed;bottom:2rem;right:2rem;display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border:none;border-radius:50px;font-weight:600;cursor:pointer;transition:all .3s ease;z-index:100}.theme-button:hover{transform:translateY(-3px);box-shadow:0 6px 12px #00000026}.theme-button:active{transform:translateY(-1px)}.theme-icon{font-size:1.2rem}@media (max-width: 768px){.theme-button{bottom:1rem;right:1rem;padding:.6rem 1rem}.theme-name{display:none}}.loader-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:#000;position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999}.loader{width:150px;height:150px}.m-path{animation:draw 4s infinite}@keyframes draw{0%{stroke-dashoffset:264.2578125}50%{stroke-dashoffset:0}to{stroke-dashoffset:-264.2578125}}.layout{min-height:100vh;display:flex;flex-direction:column;transition:all .3s ease;width:100%;overflow-x:hidden}.content-container{flex:1;width:100%;max-width:100%;margin:0 auto}main{min-height:100%;width:100%}@media (max-width: 768px){.content-container{padding:0}}*{box-sizing:border-box;margin:0;padding:0}body{overflow-x:hidden}.home{width:100%;margin:0;padding:0;font-family:Poppins,Arial,sans-serif;overflow-x:hidden;line-height:1.6}.intro-section{width:100%;padding:3rem 0;text-align:center;position:relative;overflow:hidden}.intro-grid{display:flex;flex-direction:column;align-items:center;max-width:1200px;margin:0 auto;padding:0 1rem;gap:2rem}.intro-left{display:flex;flex-direction:column;align-items:center;text-align:center}.intro-photo-container{display:flex;justify-content:center;position:relative}.intro-photo-container:after{content:"";position:absolute;bottom:-10px;left:50%;transform:translate(-50%);width:70%;height:10px;background:#0000001a;filter:blur(10px);border-radius:50%;z-index:-1}.intro-photo{width:500px;height:500px;-o-object-fit:contain;object-fit:contain;transition:transform .4s ease,filter .3s ease;border-radius:50%;box-shadow:0 8px 20px #00000026}.intro-photo:hover{transform:translateY(-5px) scale(1.02);filter:brightness(1.05)}.intro-right{display:flex;flex-direction:column;align-items:center}.intro-text{display:flex;flex-direction:column;gap:1.2rem}.intro-subtitle{font-size:.9rem;font-weight:500;font-family:Fira Mono,monospace;color:#666;text-transform:uppercase;letter-spacing:2px;margin-bottom:.5rem}.intro-heading{font-size:clamp(2.2rem,5vw,2.8rem);font-weight:700;line-height:1.1;color:#333;font-family:Francois One,sans-serif;letter-spacing:1px;margin-bottom:.6rem}.intro-bio{font-size:clamp(1rem,3vw,1.2rem);color:#555;line-height:1.7;margin-bottom:1.5rem;font-family:Poppins,sans-serif;font-weight:300}.highlight{position:relative;transition:color .3s ease;font-weight:500}.highlight:after{content:"";position:absolute;bottom:-2px;left:0;width:100%;height:2px;background-color:currentColor;transform:scaleX(0);transform-origin:right;transition:transform .3s ease}.highlight:hover:after{transform:scaleX(1);transform-origin:left}.intro-cta-container{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.intro-cta{padding:.8rem 2rem;border-radius:40px;font-weight:600;font-size:1rem;text-decoration:none;border:none;cursor:pointer;font-family:Fira Mono,monospace;letter-spacing:.5px;transition:transform .3s ease,box-shadow .3s ease;min-height:44px}.intro-cta:hover{transform:translateY(-3px);box-shadow:0 8px 20px #0003}.hero-section{width:100%;text-align:center;padding:4rem 0;position:relative;overflow:hidden}.hero-content{position:relative;max-width:900px;margin:0 auto;padding:0 1rem}.hero-section h2{font-size:clamp(2rem,5vw,2.5rem);margin-bottom:1.5rem;font-weight:700;font-family:Francois One,sans-serif;letter-spacing:1px}.hero-subtitle{font-size:clamp(1.1rem,3vw,1.3rem);margin-bottom:2rem;color:#555;font-family:Poppins,sans-serif;font-weight:300;max-width:90%;margin-left:auto;margin-right:auto}.cta-button{padding:.8rem 2rem;border-radius:40px;font-weight:600;font-size:1rem;border:none;cursor:pointer;font-family:Fira Mono,monospace;letter-spacing:.5px;transition:transform .3s ease,box-shadow .3s ease;min-height:44px}.cta-button:hover{transform:translateY(-3px);box-shadow:0 8px 20px #0003}.story-section{margin:3rem auto;padding:2rem 1rem;max-width:100%;width:100%;opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease;border-radius:15px}.story-section.fade-in{opacity:1;transform:translateY(0)}h2{font-size:clamp(1.8rem,4vw,2.2rem);margin-bottom:3rem;text-align:center;font-weight:700;color:#2c3e50;font-family:Francois One,sans-serif;position:relative;padding-bottom:.8rem;letter-spacing:1px}h2:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:60px;height:3px;background:#2c3e50;border-radius:2px}.custom-timeline{position:relative;max-width:90%;margin:0 auto;padding:2rem 0}.custom-timeline:before{content:"";position:absolute;top:0;bottom:0;width:3px;background:#a0a0a0;left:30px;border-radius:2px;z-index:0}.custom-timeline-item{position:relative;width:100%;margin-bottom:3rem;display:flex;flex-direction:column;align-items:flex-start}.custom-timeline-content{position:relative;width:100%;max-width:calc(100% - 60px);margin-left:60px;padding:1.5rem;border-radius:10px;transition:transform .4s ease,box-shadow .4s ease;z-index:1}.custom-timeline-content:hover{transform:translateY(-5px);box-shadow:0 8px 20px #0000001a}.custom-timeline-content h3{font-size:clamp(1.3rem,3vw,1.5rem);margin-bottom:1rem;font-weight:600;font-family:Francois One,sans-serif;letter-spacing:.5px}.timeline-icon{position:absolute;top:-10px;left:-10px;width:45px;height:45px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;box-shadow:0 3px 10px #0000001a}.timeline-text{font-size:clamp(.9rem,2.5vw,1rem);color:#555;line-height:1.7;margin-bottom:1rem;font-family:Poppins,sans-serif;font-weight:300}.timeline-date{font-size:.85rem;font-family:Fira Mono,monospace;color:#777;background:#f0f0f0;padding:.4rem 1rem;border-radius:20px;display:inline-block;letter-spacing:1px}.custom-timeline-item:before{content:"";position:absolute;width:18px;height:18px;border-radius:50%;background:#fff;border:3px solid #3b82f6;top:20px;left:30px;transform:translate(-50%);z-index:2;box-shadow:0 0 0 3px #3b82f633}.reason-cards{display:grid;grid-template-columns:1fr;gap:1.5rem;margin-top:1.5rem;width:100%;max-width:100%;margin-left:auto;margin-right:auto}.reason-card{display:flex;flex-direction:column;border-radius:.8rem;overflow:hidden;height:100%;position:relative}.card-content{display:flex;flex-direction:column;align-items:center;text-align:center;padding:1.5rem;height:100%}.card-icon{font-size:2rem;margin-bottom:.8rem}.reason-card h3{font-size:clamp(1.2rem,3vw,1.3rem);margin-bottom:.8rem}.reason-card p{font-size:clamp(.9rem,2.5vw,1rem);line-height:1.6}.career-choice{padding:3rem 1rem;text-align:center;margin-top:-1.5rem}.career-choice h2{margin-bottom:1.5rem}@media (min-width: 768px){.intro-section{padding:4rem 0}.intro-grid{display:grid;grid-template-columns:1fr 1fr;padding:0 2rem;gap:4rem}.intro-left{align-items:flex-start;text-align:left}.intro-photo{max-width:500px;height:500px}.intro-subtitle:before{content:"";position:absolute;top:50%;left:-40px;width:30px;height:2px;background-color:#666}.intro-heading{font-size:4.2rem}.intro-bio{font-size:1.4rem}.intro-cta-container{flex-direction:row}.hero-section{padding:7rem 0}.hero-section h2{font-size:3.5rem}.hero-subtitle{font-size:1.6rem}.story-section{margin:4rem auto;padding:3rem 2rem}.custom-timeline:before{left:50%;margin-left:-2px}.custom-timeline-item{display:flex;justify-content:space-between;align-items:flex-start}.custom-timeline-item.left{flex-direction:row}.custom-timeline-item.right{flex-direction:row-reverse}.custom-timeline-content{max-width:450px;margin-left:0;padding:2.5rem}.custom-timeline-item:before{left:50%;transform:translate(-50%)}.reason-cards{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}}@media (max-width: 480px){.intro-heading{font-size:2rem}.hero-section h2{font-size:1.8rem}.hero-subtitle{font-size:1rem}.custom-timeline-content h3{font-size:1.2rem}.card-icon{font-size:1.8rem}.reason-card h3{font-size:1.1rem}.reason-card p{font-size:.9rem}}.cv{max-width:1400px;margin:0 auto;padding:1rem}.cv-header{text-align:center;padding:1.5rem 0;border-bottom:2px solid #e0e0e0;margin-bottom:1.5rem}.cv-header h1{font-size:clamp(2rem,6vw,2.5rem);margin-bottom:.5rem}.cv-section{margin:2rem 0}.cv-section h2{font-size:clamp(1.8rem,5vw,2rem);margin-bottom:1rem}.education-grid{display:grid;grid-template-columns:1fr;justify-content:center;gap:1.5rem}.education-card{padding:1rem;border-radius:8px;transition:all .3s ease}.education-card h3{font-size:clamp(1.2rem,4vw,1.4rem);margin-bottom:.5rem}.education-institution,.education-duration{font-size:clamp(.9rem,3vw,1rem);margin:.3rem 0}.education-card:hover{transform:translateY(-3px);box-shadow:0 8px 16px #00000026}.projects-grid{display:grid;grid-template-columns:1fr;gap:1rem;justify-items:center}.card{display:grid;place-items:center;width:100%;max-width:100%;height:20rem;overflow:hidden;border-radius:.5rem;box-shadow:.2rem .2rem .4rem #0003;transition:transform .3s ease-in;position:relative;background-size:cover;background-repeat:no-repeat;background-position:center}.card>*{grid-column:1 / 2;grid-row:1 / 2}.card__content{display:flex;flex-direction:column;justify-content:flex-end;align-self:flex-end;height:100%;width:100%;padding:1rem;background:linear-gradient(180deg,#000000b3,#000000e6);z-index:2;transition:opacity .3s ease;opacity:0}.card.active .card__content,.card:hover .card__content,.card:active .card__content{opacity:1}.card__content--container{--flow-space: .5rem}.card__title{font-size:clamp(1.2rem,4vw,1.4rem);font-family:Montserrat,sans-serif;line-height:1.1}.card__title:after{content:"";position:absolute;height:.2rem;width:calc(100% + .8rem);bottom:-.35rem;left:-.8rem;background-color:var(--underline-color);transition:transform .3s ease;transform:scaleX(0);transform-origin:right}.card.active .card__title:after,.card:hover .card__title:after,.card:active .card__title:after{transform:scaleX(1);transform-origin:left}.card__description{font-family:Lato,sans-serif;font-size:clamp(.85rem,3vw,.95rem);line-height:1.3;margin-top:.5rem;opacity:0;transition:opacity .3s ease}.card.active .card__description,.card:hover .card__description,.card:active .card__description{opacity:1}.card__buttons{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem;opacity:0;transition:opacity .3s ease}.card.active .card__buttons,.card:hover .card__buttons,.card:active .card__buttons{opacity:1}.card__button{padding:.6rem 1.2rem;font-variant:small-caps;font-weight:700;border-radius:.4rem;border:none;font-family:Montserrat,sans-serif;font-size:clamp(.8rem,2.5vw,.9rem);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;text-decoration:none;transition:transform .2s ease,box-shadow .2s ease;min-height:44px}.github-button{padding:.6rem;border-radius:50%}.github-icon{font-size:1.2rem;color:#fff}.card__button:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0003}.card__button--source{background-color:#666}.card__button:focus{outline:2px solid #333;outline-offset:-4px}.card:hover .card__title,.card.active .card__title,.card:active .card__title,.card:hover .card__description,.card.active .card__description,.card:active .card__description{color:#fff!important;font-weight:700}@media (min-width: 768px){.cv{padding:2rem}.cv-header h1{font-size:3rem}.cv-section h2{font-size:2.5rem}.education-grid{grid-template-columns:repeat(2,minmax(400px,500px))}.projects-grid{grid-template-columns:repeat(2,1fr)}.card{height:24rem}.card__title{font-size:1.5rem}.card__description{font-size:1rem}.card__buttons{flex-direction:row}}@media (max-width: 480px){.cv{padding:.5rem}.education-card{padding:.8rem}.card{height:18rem}.card__title{font-size:1.1rem}.card__description{font-size:.8rem}.card__button{padding:.5rem 1rem}.github-icon{font-size:1rem}}@media (pointer: coarse){.card__content{opacity:0;transition:opacity .2s ease}.card:active .card__content,.card.active .card__content{opacity:1}.card__content--container>:not(.card__title),.card__buttons{opacity:0;transition:opacity .2s ease}.card:active .card__content--container>:not(.card__title),.card:active .card__buttons,.card.active .card__content--container>:not(.card__title),.card.active .card__buttons{opacity:1}}:root{--transition-fast: .1s ease;--transition-medium: .2s ease}@keyframes fall{to{transform:translate3d(-30em,0,0)}}@keyframes tail-fade{0%,50%{width:var(--star-tail-length);opacity:1}70%,80%{width:0;opacity:.4}to{width:0;opacity:0}}@keyframes blink{50%{opacity:.6}}.skills{min-height:60vh;padding:1rem 2rem 4rem;position:relative;overflow:hidden;background:var(--background-color);display:flex;flex-direction:column;align-items:center;justify-content:flex-start}.stars{position:absolute;top:0;left:0;width:100%;height:120%;transform:rotate(-45deg);z-index:0;pointer-events:none}.star{--star-color: var(--accent-color);--star-tail-length: 6em;--star-tail-height: 2px;--fall-duration: 6s;position:absolute;top:var(--top-offset);left:0;width:var(--star-tail-length);height:var(--star-tail-height);color:var(--star-color);background:linear-gradient(45deg,currentColor,transparent);border-radius:50%;filter:drop-shadow(0 0 6px currentColor);transform:translate3d(104em,0,0);animation:fall var(--fall-duration) var(--fall-delay) linear infinite,tail-fade var(--fall-duration) var(--fall-delay) ease-out infinite}.skills__title{text-align:center;font-family:var(--font-main);font-size:3rem;text-transform:uppercase;color:var(--text-color);margin-bottom:3rem;position:relative;z-index:1;width:-moz-fit-content;width:fit-content;margin-left:auto;margin-right:auto}.skills__title:after{content:"";position:absolute;bottom:-10px;left:20%;width:60%;height:5px;background-color:var(--accent-color);border-radius:3px}.light-theme .skills__title:after{background-color:var(--border-color)}.skills__tagline{color:var(--accent-color);font-size:1.5rem;text-align:center;margin-bottom:2rem}.skills__grid-container{background:var(--secondary-color);border-radius:20px;padding:2rem;max-width:1200px;width:100%;position:relative;overflow:hidden;box-shadow:0 10px 30px #0003;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--background-color);transition:all var(--transition-fast);z-index:1;margin-bottom:2rem}.light-theme .skills__grid-container{background:var(--primary-color);border:2px solid var(--border-color)}.skills__tabs{background:var(--secondary-color);display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1.5rem;width:100%;margin-bottom:2rem;padding:.5rem}.light-theme .skills__tabs{background:var(--primary-color)}.skills__tab{background:var(--secondary-color);border:none;color:var(--text-color);font-family:var(--font-heading);font-size:1.2rem;padding:.5rem;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;gap:.8rem;margin:0 .5rem}.light-theme .skills__tab{background:var(--primary-color);color:var(--text-color)}.skills__tab-icon{width:20px;height:20px}.skills__tab:hover{background:var(--accent-color);color:var(--text-color)}.light-theme .skills__tab:hover{background:var(--primary-color);color:var(--text-color)}.skills__tab.active{background:var(--background-color);color:var(--text-color)}.skills__grid{display:grid;grid-template-columns:repeat(3,1fr);width:100%;gap:1rem;position:relative;z-index:1}.skills__card{background:var(--primary-color);padding:1.5rem;border-radius:15px;display:flex;align-items:center;justify-content:center;gap:1.5rem;transition:all .2s cubic-bezier(.4,0,.2,1);text-align:center;position:relative;overflow:hidden;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);width:100%;box-shadow:0 6px 12px #00000026;border:2px solid transparent}.light-theme .skills__card{background:var(--primary-color)}.dark-theme .skills__card{border:2px solid var(--accent-color)}.skills__card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #0000004d;border-color:var(--accent-color);filter:brightness(1.1)}.dark-theme .skills__card:hover{background:var(--primary-color);border-color:var(--secondary-color)}.light-theme .skills__card:hover{background:var(--primary-color);border-color:var(--accent-color)}.skills__card:hover .skills__name{color:#000}.light-theme .skills__card:hover .skills__name{color:var(--text-color)}.skills__icon{width:50px;height:50px;margin-bottom:0;flex-shrink:0;transition:transform var(--transition-fast);filter:drop-shadow(0 0 4px rgba(255,255,255,.6))}.skills__card:hover .skills__icon{transform:scale(1.1) rotate(-5deg);filter:drop-shadow(0 0 8px rgba(255,255,255,.8))}.light-theme .skills__card:hover .skills__icon{filter:drop-shadow(0 0 8px rgba(255,255,255,.8))}.skills__name{color:#000;font-family:var(--font-body);font-size:1.1rem;font-weight:600;margin:0;flex-grow:1;text-shadow:0 1px 3px rgba(0,0,0,.3)}.light-theme .skills__name{color:var(--text-color)}@media (max-width: 768px){.skills{min-height:auto;padding:1.5rem .5rem}.skills__title{font-size:2.5rem;margin-bottom:1.5rem}.skills__grid-container{padding:1rem;margin:0 .5rem;border-radius:12px}.skills__tabs{background:var(--secondary-color);display:flex;flex-wrap:nowrap;overflow-x:auto;gap:.4rem;padding:.4rem;scrollbar-width:none;scroll-snap-type:x mandatory}.skills__tabs::-webkit-scrollbar{display:none}.light-theme .skills__tabs{background:var(--primary-color)}.skills__tab{font-size:.9rem;padding:.4rem .6rem;gap:.4rem;border-radius:8px;white-space:nowrap;flex-shrink:0;scroll-snap-align:start}.skills__tab-icon{width:14px;height:14px}.skills__grid{grid-template-columns:1fr;gap:.8rem}.skills__card{padding:.8rem;gap:.6rem;border-radius:8px}.skills__card:active{transform:translateY(-3px);box-shadow:0 8px 20px #0003;border-color:var(--accent-color);filter:brightness(1.1)}.dark-theme .skills__card:active{background:var(--primary-color);border-color:var(--secondary-color)}.light-theme .skills__card:active{background:var(--primary-color);border-color:var(--accent-color)}.skills__card:active .skills__name,.light-theme .skills__card:active .skills__name{color:var(--text-color)}.skills__card:active .skills__icon{transform:scale(1.1) rotate(-5deg);filter:drop-shadow(0 0 6px rgba(255,255,255,.8))}.light-theme .skills__card:active .skills__icon{filter:drop-shadow(0 0 6px rgba(255,255,255,.8))}.skills__tagline{font-size:1.1rem;margin-bottom:1rem;padding:0 .5rem}.skills__icon{width:30px;height:30px}.skills__name{font-size:.85rem}.skills__grid-container{max-width:1200px;margin:0 auto}}:root{--primary: rgba(167, 139, 250, 1);--primary-hover: rgba(139, 92, 246, 1);--error: rgba(255, 85, 85, 1);--focus-ring: rgba(167, 139, 250, .4)}.login-page{min-height:100vh;display:flex;justify-content:center;align-items:center;padding:1rem;background-size:cover;transition:background-color .3s ease}.form-container{width:100%;max-width:400px;border-radius:.8rem;padding:1.5rem;box-shadow:0 8px 20px #0000001a;transition:all .3s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.1)}.title{text-align:center;font-size:clamp(1.25rem,4vw,1.5rem);line-height:1.2;font-weight:700;margin-bottom:1rem;transition:color .3s ease}.form{margin-top:1rem}.input-group{margin-bottom:1rem;position:relative}.input-group label{display:block;font-size:.8rem;margin-bottom:.4rem;font-weight:500;transition:color .3s ease}.input-group input{width:100%;border-radius:.4rem;border:1px solid rgba(55,65,81,.5);outline:0;padding:.75rem .9rem;transition:all .2s ease;font-size:.9rem;min-height:44px}.input-group input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--focus-ring)}.input-group input::-moz-placeholder{opacity:.5}.input-group input::placeholder{opacity:.5}.error{color:var(--error);text-align:center;margin:.5rem 0;font-size:.8rem;font-weight:500;padding:.4rem;border-radius:.3rem;background-color:#ff55551a;animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.sign{display:block;width:100%;background-color:var(--primary);padding:.75rem;text-align:center;color:#fff;border:none;border-radius:.4rem;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s ease;min-height:44px}.sign:hover{background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #a78bfa4d}.sign:active{transform:translateY(0)}.sign:disabled{opacity:.7;cursor:not-allowed}.forgot{display:flex;justify-content:flex-end;font-size:.7rem;line-height:1rem;margin:-.4rem 0 1rem;transition:color .3s ease}.forgot a{text-decoration:none;font-weight:500;transition:color .2s ease}.forgot a:hover{text-decoration:underline;color:var(--primary)}.signup{text-align:center;font-size:.8rem;margin-top:1rem;transition:color .3s ease}.signup a{text-decoration:none;font-weight:500;transition:color .2s ease}.signup a:hover{text-decoration:underline;color:var(--primary)}.social-message,.social-icons{display:none}@media (max-width: 480px){.form-container{padding:1rem;max-width:95%}.title{font-size:1.1rem}.input-group input{padding:.6rem .8rem}.sign{padding:.6rem}}.input-group input:focus-visible{outline:2px solid var(--primary);outline-offset:1px}.sign:focus-visible{outline:2px solid white;outline-offset:2px}.sign.loading{position:relative;color:transparent}.sign.loading:after{content:"";position:absolute;width:18px;height:18px;top:50%;left:50%;margin-left:-9px;margin-top:-9px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin .8s infinite linear}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.admin-page{min-height:calc(100vh - 4rem);padding:1rem 2.5rem 2.5rem;font-family:Roboto,sans-serif;transition:all .3s ease;position:relative;overflow-x:hidden;margin-top:0}.admin-container{max-width:1400px;margin:0 auto;animation:fadeIn .8s ease-out;text-align:center}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.admin-container h1{font-size:2.5rem;font-weight:700;margin:2rem auto;text-align:center;letter-spacing:.05rem;display:block;width:-moz-fit-content;width:fit-content;position:relative}.admin-container h1:after{content:"";position:absolute;bottom:-10px;left:0;right:0;height:3px;background:currentColor;transform:scaleX(0);transform-origin:center;animation:headlineUnderline 1.2s forwards ease-out .3s}@keyframes headlineUnderline{to{transform:scaleX(1)}}.reports-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin:2.5rem 0}.report-card{padding:2rem;border-radius:12px;box-shadow:0 6px 12px #0000001a;transition:transform .3s ease,box-shadow .3s ease;background:linear-gradient(145deg,#ffffffe6,#f5f5f5e6);display:flex;flex-direction:column;position:relative}.report-card:hover{transform:translateY(-5px);box-shadow:0 12px 24px #00000026}.report-card h2{font-size:1.5rem;font-weight:600;margin-bottom:1.5rem;text-transform:uppercase;letter-spacing:.03rem;position:relative}.report-card h2:before{content:"";position:absolute;left:-1rem;top:50%;width:6px;height:0;transform:translateY(-50%);background-color:currentColor;opacity:.5;transition:height .3s ease}.report-card:hover h2:before{height:70%}.report-content{display:flex;flex-direction:column;gap:1rem;margin-top:1rem;position:relative;z-index:2}.chart-container{position:relative;height:250px;width:100%;z-index:2}.filter-buttons{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-top:1rem}.filter-button{padding:.5rem 1rem;border:none;border-radius:20px;background-color:#0000000d;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.filter-button:after{content:"";position:absolute;top:50%;left:50%;width:100%;height:0;background-color:#ffffff1a;border-radius:50%;transform:translate(-50%,-50%);opacity:0;transition:all .3s ease}.filter-button:hover:after{opacity:1;height:200%}.filter-button:hover{background-color:#0000001a;transform:scale(1.05)}.filter-button.clear{background-color:#ff00001a}.filter-button.clear:hover{background-color:#f003}.users-table{margin-top:3rem;padding:2rem;border-radius:12px;box-shadow:0 6px 12px #0000001a;background:linear-gradient(145deg,#ffffffe6,#f5f5f5e6);overflow-x:auto;position:relative}.users-table h2{font-size:1.8rem;font-weight:600;margin-bottom:1.5rem}.users-table table{width:100%;border-collapse:collapse}.users-table th,.users-table td{padding:1rem;text-align:left;border-bottom:1px solid rgba(0,0,0,.08)}.users-table th{font-weight:700;text-transform:uppercase;font-size:.95rem;color:#333}.users-table td{font-size:.9rem;transition:background-color .3s ease}.users-table tr{transition:all .2s ease}.users-table tr:hover{background-color:#0000000a;transform:translate(5px)}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1.5rem}.pagination button{padding:.5rem 1.2rem;border:none;border-radius:20px;background-color:#0000000d;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.pagination button:after{content:"";position:absolute;top:50%;left:50%;width:5%;height:5%;background-color:#ffffff4d;border-radius:50%;transform:translate(-50%,-50%);opacity:0;transition:all .5s ease}.pagination button:hover:after{width:200%;height:200%;opacity:1}.pagination button:hover{background-color:#0000001a;transform:scale(1.05)}.pagination button:disabled{background-color:#00000008;cursor:not-allowed;transform:none}.pagination button:disabled:after{display:none}.pagination span{font-size:.9rem;font-weight:500}.recharts-default-tooltip{background-color:#ffffffd9!important;border:1px solid #ccc!important;border-radius:8px!important;padding:10px!important;box-shadow:0 2px 8px #00000026!important;animation:tooltipPop .3s ease-out!important}@keyframes tooltipPop{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.recharts-tooltip-label{font-weight:600!important;margin-bottom:5px!important}.recharts-sector:hover,.recharts-rectangle:hover{opacity:.8;transition:all .3s ease}.recharts-legend-item{cursor:pointer;transition:all .3s ease}.recharts-legend-item:hover{transform:translateY(-2px)}.dark-mode .users-table,.dark-mode .report-card{background:linear-gradient(145deg,#323232f2,#1e1e1ef2)}.dark-mode .users-table th{color:#f0f0f0}.dark-mode .users-table tr:hover{background-color:#ffffff0d}.dark-mode .recharts-default-tooltip{background-color:#282828f2!important;border:1px solid #555!important}.dark-mode .report-card h2,.dark-mode .users-table h2{color:#fff}.dark-mode .pagination button{color:#fff;background-color:#ffffff1a}.dark-mode .pagination button:hover{background-color:#fff3}.dark-mode .pagination button:disabled{color:#ccc;background-color:#ffffff0d}.animate-header{animation:fadeInDown .5s ease-out}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.animate-card{animation:fadeInUp .5s ease-out;animation-fill-mode:both}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.reports-grid .animate-card:nth-child(1){animation-delay:.1s}.reports-grid .animate-card:nth-child(2){animation-delay:.2s}.reports-grid .animate-card:nth-child(3){animation-delay:.3s}.reports-grid .animate-card:nth-child(4){animation-delay:.4s}.animate-table{animation:fadeIn .5s ease-out .5s;animation-fill-mode:both}@media (max-width: 768px){.admin-page{padding:1.5rem}.admin-container h1{font-size:2rem}.reports-grid{grid-template-columns:1fr;gap:1.5rem}.report-card{padding:1.5rem}.chart-container{height:200px}.users-table{padding:1.5rem}.users-table th,.users-table td{padding:.75rem;font-size:.85rem}}@media (max-width: 480px){.admin-page{padding:1rem}.chart-container{height:180px}.filter-button{padding:.4rem .8rem;font-size:.8rem}.pagination button{padding:.4rem 1rem;font-size:.8rem}}#root{width:100%;max-width:100%;margin:0;text-align:center}.logo{height:5em;padding:1em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 1.5em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 1.5em #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:1.5em}.read-the-docs{color:#888}@media (max-width: 480px){.logo{height:4em;padding:.8em}.card{padding:1em}}
