@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Space+Grotesk:wght@400;500;600;700&display=swap";.page-content{padding-top:64px}.section-full{width:100%}.section-full:first-child>.container{padding-block:0}.divider.container{margin-block:0}.AboutPage{display:flex;flex-direction:column;gap:var(--sp-lg);margin-inline:auto}.AboutText{width:100%}.AboutText p{font-family:var(--font-body);font-size:var(--text-bm-size);font-weight:400;line-height:var(--text-bm-lh);color:var(--text-secondary)}.AboutText p b{color:var(--text-primary);font-weight:600}@media (max-width: 768px){.AboutPage{max-width:100%;gap:var(--sp-md)}.AboutTextHeading{font-size:clamp(1.25rem,5vw,1.8rem)}}section.contact-us{display:flex;gap:var(--sp-xl);width:100%}.contact-left{flex:1}.contact-details{display:flex;flex-direction:column;gap:var(--sp-sm);margin-bottom:var(--sp-lg)}.detail-item{display:flex;align-items:center;gap:var(--sp-sm);text-decoration:none;color:var(--text-secondary);font-size:var(--text-bm-size);transition:var(--transition)}a.detail-item:hover{color:var(--accent);transform:translate(4px)}.detail-icon{width:36px;height:36px;background:var(--surface-container-high);border:1px solid var(--card-border);border-radius:var(--r-base);display:flex;align-items:center;justify-content:center;color:var(--accent)}.contact-us .section-title{display:flex;align-items:center;gap:var(--sp-sm)}section.contact-us .icon-envelope{color:var(--accent);font-size:1.5rem}section.contact-us .sub-title{font-family:var(--font-body);font-size:var(--text-bm-size);color:var(--text-secondary);line-height:var(--text-bm-lh);margin-bottom:var(--sp-lg);max-width:440px}section.contact-us form{display:flex;flex-direction:column;gap:var(--sp-md)}section.contact-us form .flex{flex-direction:column;align-items:flex-start;gap:var(--sp-xs)}section.contact-us label{font-family:var(--font-display);font-size:var(--text-lm-size);font-weight:var(--text-lm-weight);letter-spacing:var(--text-lm-ls);text-transform:uppercase;color:var(--text-muted)}section.contact-us #email,section.contact-us #message{display:block;width:100%;padding:10px var(--sp-sm);background:var(--surface-container);border:1px solid var(--card-border);border-bottom:2px solid var(--outline);border-radius:var(--r-base);color:var(--text-primary);font-family:var(--font-body);font-size:var(--text-bm-size);transition:border-color var(--transition),box-shadow var(--transition)}section.contact-us #email::placeholder,section.contact-us #message::placeholder{color:var(--text-muted)}section.contact-us #email:hover,section.contact-us #message:hover{border-bottom-color:var(--on-surface-variant)}section.contact-us #email:focus,section.contact-us #message:focus{border-bottom-color:var(--accent);box-shadow:0 2px 0 var(--accent),0 0 12px var(--accent-glow);outline:none}section.contact-us #message{min-height:130px;resize:vertical}section.contact-us .submit{display:inline-flex;align-items:center;justify-content:center;padding:12px var(--sp-md);border-radius:var(--r-base);background:var(--accent);color:var(--on-primary);font-family:var(--font-display);font-size:var(--text-ll-size);font-weight:700;letter-spacing:var(--text-ll-ls);text-transform:uppercase;transition:var(--transition);border:1px solid var(--accent-dim);align-self:flex-start;margin-top:var(--sp-xs)}section.contact-us .submit:hover:not(:disabled){transform:scale(1.02);box-shadow:0 0 16px var(--accent-glow)}section.contact-us .success{align-items:center;gap:var(--sp-xs);font-size:var(--text-bm-size);color:var(--accent);margin-top:var(--sp-xs)}section.contact-us .animation{flex-shrink:0;width:clamp(200px,30vw,380px);opacity:.85;filter:drop-shadow(0 0 30px rgba(110,224,0,.1))}@media (max-width: 850px){section.contact-us{flex-direction:column;gap:var(--sp-md)}section.contact-us>div:first-child{max-width:100%}section.contact-us .animation{display:none}section.contact-us .submit{align-self:stretch;text-align:center}}#experience{text-align:center;margin-bottom:var(--sp-lg)}.subtitle-experience{font-family:var(--font-display);font-size:var(--text-ll-size);font-weight:var(--text-ll-weight);letter-spacing:var(--text-ll-ls);text-transform:uppercase;color:var(--accent);margin-bottom:var(--sp-sm)}.title-experience{font-family:var(--font-display);font-size:var(--text-hm-size);font-weight:var(--text-hm-weight);line-height:var(--text-hm-lh);letter-spacing:var(--text-hm-ls);color:var(--text-primary)}.experience-section,.experience-stack{position:relative}.experience-card-shell{height:90vh;display:flex;align-items:flex-start;justify-content:center;position:sticky;top:64px;padding:var(--sp-lg) var(--sp-gutter) 0}@media (max-width: 768px){.experience-card-shell{position:relative;height:auto;top:0}}.experience-card{position:relative;width:min(100%,1100px);min-height:480px;border-radius:var(--r-base);border:1px solid var(--card-border);background:var(--card-bg);overflow:hidden;transform-origin:top center}.experience-card__glow{position:absolute;inset:auto auto -40px -40px;width:200px;height:200px;border-radius:var(--r-full);filter:blur(60px);pointer-events:none;opacity:.1}.experience-card__inner{position:relative;z-index:1;display:flex;flex-direction:column;gap:var(--sp-md);padding:var(--sp-md)}.experience-card__header{display:grid;grid-template-columns:80px 1fr;gap:var(--sp-md);align-items:start}.experience-card__icon{width:80px;height:80px;border-radius:var(--r-base);overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--surface-container);border:1px solid var(--card-border)}.experience-card__icon-image{width:70%;height:70%;object-fit:contain}.experience-card__icon-fallback{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--text-primary)}.experience-card__title-block{min-width:0}.experience-card__eyebrow{font-family:var(--font-display);font-size:var(--text-ll-size);font-weight:var(--text-ll-weight);text-transform:uppercase;letter-spacing:var(--text-ll-ls);margin-bottom:var(--sp-xs)}.experience-card__title{font-family:var(--font-display);font-size:var(--text-hs-size);font-weight:var(--text-hs-weight);line-height:var(--text-hs-lh);color:var(--text-primary);margin-bottom:var(--sp-xs)}.experience-card__date{font-family:var(--font-body);font-size:var(--text-ll-size);color:var(--text-muted)}.experience-card__divider{width:100%;height:1px;background:var(--card-border)}.experience-card__points{list-style:none;display:grid;gap:var(--sp-sm);margin:0;padding:0}.experience-card__point{position:relative;padding-left:1.5rem;color:var(--text-primary);font-family:var(--font-body);font-size:var(--text-bl-size);line-height:1.6}.experience-card__point:before{content:"";position:absolute;left:0;top:.6rem;width:8px;height:8px;border-radius:var(--r-sm);background:var(--accent)}.experience-card__tags{display:flex;flex-wrap:wrap;gap:var(--sp-xs);margin-top:auto}.experience-card__tag{border:1px solid var(--card-border);border-radius:var(--r-sm);padding:4px 10px;font-family:var(--font-display);font-size:var(--text-ll-size);letter-spacing:.02em;text-transform:uppercase;background:var(--surface-container-low);color:var(--text-secondary)}@media (max-width: 900px){.experience-stack{margin-top:10vh}.experience-card-shell{padding:0 var(--sp-sm)}.experience-card{min-height:auto}.experience-card__header{grid-template-columns:1fr}}@media (max-width: 640px){.experience-card-shell{height:auto;min-height:100vh;align-items:flex-start;padding-top:4rem;padding-bottom:2rem}.experience-card{top:0!important}.experience-card__inner{padding:var(--sp-sm)}.experience-card__point{font-size:var(--text-bm-size)}}footer{border-top:1px solid var(--card-border);background:var(--surface-container-lowest)}footer .container{padding-block:var(--sp-lg);display:flex;align-items:center;justify-content:space-between;gap:var(--sp-md)}footer .container p{font-family:var(--font-body);font-size:var(--text-bm-size);color:var(--text-muted)}footer ul{display:flex;gap:var(--sp-sm);list-style:none}footer ul a{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--r-base);border:1px solid var(--card-border);background:var(--surface-container);color:var(--text-secondary);transition:var(--transition)}footer ul a:hover{color:var(--accent);border-color:var(--accent);box-shadow:0 0 8px var(--accent-glow)}.social-icon{width:18px;height:18px}@media (max-width: 640px){footer .container{flex-direction:column;text-align:center;gap:var(--sp-md)}}header{position:fixed;top:0;left:0;right:0;z-index:100;height:64px;display:flex;align-items:center;justify-content:space-between;padding-inline:var(--sp-margin);background:var(--surface-container-lowest);border-bottom:1px solid var(--card-border);transition:background var(--transition),border-color var(--transition)}header .logo{font-family:var(--font-display);font-size:20px;font-weight:700;letter-spacing:-.02em;color:var(--accent);transition:transform var(--transition)}header .logo:hover{transform:scale(1.05)}header ul.menu{display:flex;gap:var(--sp-lg);list-style:none}header ul.menu li a{font-family:var(--font-display);font-size:var(--text-ll-size);font-weight:var(--text-ll-weight);letter-spacing:var(--text-ll-ls);text-transform:uppercase;color:var(--text-secondary);transition:color var(--transition);position:relative;padding-bottom:4px}header ul.menu li a:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--accent);transition:width var(--transition-md)}header ul.menu li a:hover{color:var(--text-primary)}header ul.menu li a:hover:after{width:100%}header .model{display:none;color:var(--text-primary);font-size:1.4rem}.menu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;justify-content:flex-end}.menu-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.menu-drawer{position:relative;width:min(85%,360px);height:100%;background:var(--surface-container-lowest);border-left:1px solid var(--card-border);padding:var(--sp-md);display:flex;flex-direction:column;gap:var(--sp-lg);box-shadow:-10px 0 30px #0000004d}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:var(--sp-sm);border-bottom:1px solid var(--card-border)}.menu-drawer ul{list-style:none;display:flex;flex-direction:column;gap:var(--sp-md)}.menu-drawer ul li a{font-family:var(--font-display);font-size:var(--text-hs-size);font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);transition:var(--transition);display:block}.menu-drawer ul li a:hover{color:var(--accent);padding-left:8px}.menu_close.icon-clear{font-size:1.6rem;color:var(--text-secondary);background:var(--surface-container-high);width:40px;height:40px;border-radius:var(--r-base);display:flex;align-items:center;justify-content:center;transition:var(--transition)}.menu_close.icon-clear:hover{color:var(--error);transform:rotate(90deg)}@media (max-width: 768px){header ul.menu{display:none}header .model{display:flex;align-items:center}header{padding-inline:var(--sp-md)}}section.hero{min-height:calc(100vh - 64px);display:flex;align-items:center;justify-content:space-between;gap:var(--sp-lg);position:relative}section.hero:before{content:"";position:absolute;top:10%;left:-200px;width:600px;height:600px;background:radial-gradient(circle,rgba(110,224,0,.05) 0%,transparent 70%);pointer-events:none}section.hero .first_section{flex:1;max-width:640px;padding-block:var(--sp-xl);z-index:1}section.hero .section-label{display:inline-flex;align-items:center;gap:var(--sp-xs);margin-bottom:var(--sp-md)}section.hero .section-label:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent);animation:blink 1.8s ease-in-out infinite;margin-right:8px}@keyframes blink{0%,to{opacity:1}50%{opacity:.25}}section.hero .section-title{font-family:var(--font-display);font-size:var(--text-hl-size);font-weight:var(--text-hl-weight);line-height:var(--text-hl-lh);letter-spacing:var(--text-hl-ls);color:var(--text-primary);display:flex;align-items:center;flex-wrap:wrap;gap:var(--sp-sm);margin-bottom:var(--sp-md)}section.hero .blob{display:inline-block;animation:wave 2.8s ease-in-out infinite;transform-origin:70% 70%}@keyframes wave{0%{transform:rotate(0)}15%{transform:rotate(14deg)}30%{transform:rotate(-8deg)}40%{transform:rotate(14deg)}50%{transform:rotate(-4deg)}60%{transform:rotate(10deg)}70%{transform:rotate(0)}to{transform:rotate(0)}}section.hero .subtitle{font-family:var(--font-body);font-size:var(--text-bl-size);font-weight:400;line-height:var(--text-bl-lh);color:var(--text-secondary);max-width:500px;margin-bottom:var(--sp-sm)}section.hero .icons{display:flex;gap:var(--sp-sm);margin-bottom:var(--sp-lg)}section.hero .icons>div>a{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--r-base);background:var(--surface-container);border:1px solid var(--card-border);color:var(--text-secondary);transition:var(--transition)}section.hero .icons>div>a:hover{color:var(--accent);border-color:var(--accent);box-shadow:0 0 10px var(--accent-glow)}section.hero .tech{flex-direction:column;align-items:flex-start;gap:var(--sp-sm);margin-bottom:var(--sp-lg)}section.hero .tech-title{font-family:var(--font-display);font-size:var(--text-lm-size);font-weight:var(--text-lm-weight);letter-spacing:var(--text-lm-ls);text-transform:uppercase;color:var(--text-muted)}section.hero .tech-skills{display:flex;flex-wrap:wrap;gap:var(--sp-xs);list-style:none}section.hero .tech-skills li{display:flex;align-items:center;transition:var(--transition)}section.hero .tech-skills li:hover{filter:drop-shadow(0 0 8px var(--accent-glow))}section.hero .tech-skills img{border-radius:var(--r-base);height:40px;width:auto}section.hero .cv-btn{display:inline-flex;align-items:center;gap:var(--sp-xs);padding:12px 24px;border-radius:var(--r-base);background:var(--accent);color:var(--on-primary);font-family:var(--font-display);font-size:var(--text-ll-size);font-weight:700;letter-spacing:var(--text-ll-ls);text-transform:uppercase;transition:var(--transition);border:1px solid var(--accent-dim)}section.hero .cv-btn:hover{transform:scale(1.02);box-shadow:0 0 20px var(--accent-glow)}section.hero .second_section{flex-shrink:0;z-index:1;position:relative}section.hero .second_section:after{content:"";position:absolute;top:-6px;right:-6px;bottom:-6px;left:-6px;border-radius:50%;background:transparent;border:1px solid var(--outline-variant);pointer-events:none}section.hero .MyImage{width:clamp(220px,26vw,620px);height:clamp(220px,26vw,620px);border-radius:50%;object-fit:cover;object-position:center top;border:2px solid var(--outline);animation:float 7s ease-in-out infinite;box-shadow:0 0 40px #6ee0001a}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}@media (max-width: 860px){section.hero{flex-direction:column-reverse;text-align:center;padding-top:80px;padding-bottom:var(--sp-lg);min-height:auto;gap:var(--sp-md)}section.hero .first_section{max-width:100%;padding-block:var(--sp-md)}section.hero .greeting-tag,section.hero .icons{justify-content:center}section.hero .tech{align-items:center}section.hero .tech-skills{justify-content:center}section.hero .subtitle{margin-inline:auto}section.hero .title{justify-content:center}section.hero .cv-btn{align-self:center}section.hero .MyImage{width:200px;height:200px}}main#project{display:flex;flex-direction:column;align-items:center;gap:var(--sp-lg)}.projects-header{text-align:center;width:100%}.projects-header h2{font-family:var(--font-display);font-size:var(--text-hm-size);color:var(--text-primary);margin-top:var(--sp-xs)}.left-section{display:flex;flex-wrap:wrap;gap:var(--sp-sm);justify-content:center}.left-section button{font-family:var(--font-display);font-size:var(--text-ll-size);text-transform:uppercase;letter-spacing:.05em;padding:8px 16px;border:1px solid var(--card-border);border-radius:var(--r-base);color:var(--text-secondary);transition:var(--transition)}.left-section button:hover{border-color:var(--accent);color:var(--text-primary)}.left-section button.active{background:var(--accent);color:var(--on-primary);border-color:var(--accent)}.right-section{display:flex;flex-wrap:wrap;gap:var(--sp-md);align-items:center;justify-content:center;width:100%}.card{max-width:600px;width:100%;background:var(--surface-container-low);border:1px solid var(--card-border);border-radius:var(--r-lg);overflow:hidden;cursor:pointer;transition:var(--transition);display:flex;flex-direction:column}.card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 4px 20px var(--accent-glow)}.card img{width:100%;height:300px;object-fit:contain;border-bottom:1px solid var(--card-border)}.card .box{padding:var(--sp-md);flex:1;display:flex;flex-direction:column}.card .title{font-family:var(--font-display);font-size:var(--text-hs-size);color:var(--text-primary);margin-bottom:var(--sp-xs)}.card .sub-title{font-size:var(--text-bm-size);color:var(--text-secondary);line-height:1.5}.card-description{display:flex;flex-direction:column;align-items:flex-start;gap:8px;margin-bottom:var(--sp-sm);flex:1}.read-more-btn{padding:0;border:0;background:transparent;color:var(--accent);font-family:var(--font-display);font-size:var(--text-ll-size);font-weight:600;letter-spacing:.03em;cursor:pointer;transition:var(--transition)}.read-more-btn:hover{color:var(--text-primary)}.read-more-btn:focus-visible{outline:2px solid var(--accent);outline-offset:4px}.card-stack{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:var(--sp-md)}.stack-tag{font-family:var(--font-display);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;padding:2px 8px;background:var(--surface-container-high);border:1px solid var(--card-border);border-radius:var(--r-sm);color:var(--accent);transition:var(--transition)}.card:hover .stack-tag{border-color:var(--accent);background:#6ee0000d}.card .icons{justify-content:flex-end}.card .icon{gap:var(--sp-sm)}.card .icon a{font-size:1.2rem;color:var(--text-secondary);transition:var(--transition)}.card .icon a:hover{color:var(--accent)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--sp-md)}.project-modal{background:var(--surface-container);border:1px solid var(--card-border);border-radius:var(--r-xl);width:100%;max-width:1400px;max-height:90vh;position:relative;z-index:1001;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 50px #00000080}.modal-close{position:absolute;top:20px;right:20px;z-index:10;font-size:1.5rem;color:var(--text-secondary);background:var(--surface-container-high);width:40px;height:40px;border-radius:var(--r-base);display:flex;align-items:center;justify-content:center;transition:var(--transition)}.modal-close:hover{color:var(--error);background:var(--surface-bright)}.modal-content{display:grid;grid-template-columns:1.5fr 1fr;height:100%;overflow:hidden}.modal-media{display:flex;gap:var(--sp-sm);padding:var(--sp-md);background:var(--surface-container-lowest);height:600px}.image-preview{flex:1;background:#000;border-radius:var(--r-lg);overflow:hidden;display:flex;align-items:center;justify-content:center}.image-preview img{width:100%;height:100%;object-fit:contain}.image-thumbnails{width:100px;display:flex;flex-direction:column;gap:var(--sp-sm);overflow-y:auto;padding-right:4px}.image-thumbnails::-webkit-scrollbar{width:4px}.image-thumbnails::-webkit-scrollbar-thumb{background:var(--card-border);border-radius:4px}.image-thumbnails img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:var(--r-base);cursor:pointer;border:2px solid transparent;transition:var(--transition);opacity:.6}.image-thumbnails img:hover{opacity:1}.image-thumbnails img.active-thumb{border-color:var(--accent);opacity:1;box-shadow:0 0 10px var(--accent-glow)}.modal-info{padding:var(--sp-lg) var(--sp-md);display:flex;flex-direction:column;gap:var(--sp-md);overflow-y:auto}.modal-title{font-family:var(--font-display);font-size:var(--text-hm-size);color:var(--text-primary);margin-bottom:var(--sp-xs)}.modal-desc{font-size:var(--text-bm-size);color:var(--text-secondary);line-height:1.7}.modal-stack{display:flex;flex-wrap:wrap;gap:var(--sp-xs);margin-bottom:var(--sp-xs)}.stack-badge{font-family:var(--font-display);font-size:var(--text-ll-size);font-weight:500;padding:4px 10px;background:var(--surface-container-high);border:1px solid var(--card-border);border-radius:var(--r-sm);color:var(--accent)}.modal-details{display:flex;flex-direction:column;gap:var(--sp-sm)}.modal-details-heading{font-family:var(--font-display);font-size:var(--text-hs-size);font-weight:600;color:var(--text-primary);border-left:3px solid var(--accent);padding-left:var(--sp-sm)}.modal-details ul{list-style:none;display:flex;flex-direction:column;gap:var(--sp-xs)}.modal-details li{font-family:var(--font-body);font-size:var(--text-bm-size);color:var(--text-secondary);line-height:1.6;position:relative;padding-left:var(--sp-md)}.modal-details li:before{content:"›";position:absolute;left:0;color:var(--accent);font-weight:700;font-size:1.2rem;line-height:1;top:2px}.modal-actions{display:flex;gap:var(--sp-sm);margin-top:var(--sp-md)}.modal-btn{flex:1;padding:12px;border-radius:var(--r-base);display:flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-display);font-weight:600;text-transform:uppercase;letter-spacing:.05em;transition:var(--transition)}.modal-btn.primary{background:var(--accent);color:var(--on-primary)}.modal-btn.primary:hover{transform:scale(1.02);box-shadow:0 0 20px var(--accent-glow)}.modal-btn.secondary{background:var(--surface-container-high);color:var(--text-primary);border:1px solid var(--card-border)}.modal-btn.secondary:hover{border-color:var(--accent);background:var(--surface-bright)}@media (max-width: 900px){.modal-content{grid-template-columns:1fr;overflow-y:auto}.modal-media{height:400px;flex-direction:column}.image-thumbnails{width:100%;flex-direction:row;height:80px}.image-thumbnails img{width:120px;height:100%}.project-modal{max-height:95vh}}@media (max-width: 640px){.modal-media{height:300px}.modal-actions{flex-direction:column}}.previewer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#0b0c10;background-image:radial-gradient(circle at center,rgba(110,224,0,.05) 0%,transparent 70%),linear-gradient(rgba(255,255,255,.01) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.01) 1px,transparent 1px);background-size:100% 100%,40px 40px,40px 40px;z-index:2000;display:flex;flex-direction:column;color:var(--text-primary);overflow:hidden}.previewer-topbar{height:70px;background:#121212d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--card-border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--sp-md);z-index:2010;box-shadow:0 4px 30px #0000004d}.topbar-left,.topbar-center,.topbar-right{display:flex;align-items:center;gap:var(--sp-sm)}.topbar-left{flex:1}.topbar-center{flex:2;justify-content:center}.topbar-right{flex:1;justify-content:flex-end}.topbar-project-name{font-family:var(--font-display);font-size:1.1rem;font-weight:600;color:var(--text-primary);letter-spacing:.03em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:250px}.divider-vr{width:1px;height:24px;background:var(--card-border);margin:0 var(--sp-xs)}.topbar-btn{background:var(--surface-container-high);border:1px solid var(--card-border);color:var(--text-secondary);font-family:var(--font-display);font-weight:500;font-size:.9rem;padding:8px 16px;border-radius:var(--r-base);display:flex;align-items:center;gap:8px;cursor:pointer;transition:var(--transition)}.topbar-btn:hover{color:var(--text-primary);border-color:var(--accent);background:var(--surface-bright)}.topbar-btn.back-btn{background:transparent;border-color:transparent;color:var(--text-secondary)}.topbar-btn.back-btn:hover{color:var(--error);background:#ff00000d}.topbar-btn.res-btn.active{background:var(--accent);color:var(--on-primary);border-color:var(--accent);box-shadow:0 0 15px var(--accent-glow)}.topbar-btn.live-btn{background:var(--accent);color:var(--on-primary);border-color:var(--accent)}.topbar-btn.live-btn:hover{transform:scale(1.02);box-shadow:0 0 15px var(--accent-glow)}.previewer-viewport-container{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--sp-lg);overflow:auto;position:relative}.device-frame{transition:all .4s cubic-bezier(.25,1,.5,1);background:#000;box-shadow:0 25px 60px #000000b3;overflow:hidden;position:relative;border-radius:var(--r-lg)}.device-frame.desktop{width:100%;height:100%;border-radius:0;border:none;box-shadow:none}.device-frame.tablet{width:768px;height:95%;max-height:1024px;border:14px solid #282828;border-radius:32px}.device-frame.mobile{width:375px;height:95%;max-height:812px;border:14px solid #282828;border-radius:40px}.device-notch{position:absolute;top:0;left:50%;transform:translate(-50%);width:160px;height:28px;background:#282828;border-bottom-left-radius:18px;border-bottom-right-radius:18px;z-index:100;display:flex;align-items:center;justify-content:center;gap:12px}.device-notch .camera{width:10px;height:10px;border-radius:50%;background:#111;box-shadow:inset 0 1px 2px #fff3}.device-notch .speaker{width:50px;height:4px;border-radius:2px;background:#151515}.device-camera-tablet{position:absolute;top:-8px;left:50%;transform:translate(-50%);width:8px;height:8px;border-radius:50%;background:#151515;z-index:100}.previewer-iframe{width:100%;height:100%;border:none;background:#fff;border-radius:inherit}.previewer-viewport-container::-webkit-scrollbar{width:8px;height:8px}.previewer-viewport-container::-webkit-scrollbar-thumb{background:var(--card-border);border-radius:4px}.previewer-viewport-container::-webkit-scrollbar-thumb:hover{background:var(--accent)}@media (max-width: 768px){.previewer-topbar{justify-content:space-between}.topbar-left,.topbar-right{flex:0 1 auto}.topbar-project-name,.topbar-center,.topbar-btn span{display:none}.topbar-btn{padding:8px 12px}}.observer-trigger{display:flex;justify-content:center;align-items:center;width:100%;padding:var(--sp-lg) 0;margin-top:var(--sp-md)}.loader-dots{display:flex;gap:8px}.loader-dots span{width:10px;height:10px;background-color:var(--accent);border-radius:50%;box-shadow:0 0 8px var(--accent-glow);display:inline-block;animation:loaderDotPulse 1.2s infinite ease-in-out both}.loader-dots span:nth-child(1){animation-delay:-.32s}.loader-dots span:nth-child(2){animation-delay:-.16s}@keyframes loaderDotPulse{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1.2);opacity:1}}.plan-section{display:flex;flex-direction:column;gap:var(--sp-lg);width:100%;padding-block:var(--sp-xl)}.plan-header{text-align:center;max-width:800px;margin-inline:auto}.plan-header .section-label{color:var(--accent);font-weight:700;letter-spacing:.2em}.plan-header .plan-title{font-family:var(--font-display);font-size:clamp(2.5rem,6vw,4rem);font-weight:700;color:var(--text-primary);margin-top:var(--sp-xs)}.plan-header .plan-title i{color:var(--accent);font-family:serif}.plan-subtitle{color:var(--text-secondary);font-size:var(--text-bl-size);margin-top:var(--sp-sm);line-height:1.6}.plan-note{background:#7cfc0008;border:1px solid var(--card-border);border-left:4px solid var(--accent);padding:var(--sp-md);border-radius:var(--r-md);display:flex;align-items:flex-start;gap:var(--sp-sm);max-width:800px;margin-inline:auto}.plan-note span{color:var(--accent);font-size:1.2rem;margin-top:2px}.plan-note p{color:var(--text-secondary);font-size:var(--text-bm-size);line-height:1.5}.plan-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--sp-md);margin-top:var(--sp-md)}.plan-card{background:var(--surface-container-low);border:1px solid var(--card-border);border-radius:var(--r-lg);padding:var(--sp-lg) var(--sp-md);display:flex;flex-direction:column;transition:var(--transition)}.plan-card:hover{transform:translateY(-8px);border-color:var(--accent)}.plan-card.popular{border-color:var(--accent);box-shadow:0 0 30px var(--accent-glow)}.plan-tag{font-family:var(--font-display);font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.15em;color:var(--text-muted);border:1px solid var(--card-border);padding:4px 10px;border-radius:var(--r-sm);display:inline-block;margin-bottom:var(--sp-md)}.plan-icon{width:50px;height:50px;background:var(--surface-container-high);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;margin-bottom:var(--sp-sm);color:var(--accent)}.plan-icon svg{width:24px;height:24px}.plan-name{font-family:var(--font-display);font-size:var(--text-hs-size);color:var(--text-primary);margin-bottom:var(--sp-xs)}.plan-price{display:flex;align-items:flex-start;gap:2px;margin-bottom:var(--sp-sm)}.plan-price .currency{font-size:1.2rem;font-weight:700;color:var(--accent);margin-top:6px}.plan-price .price{font-family:var(--font-display);font-size:2.8rem;font-weight:700;color:var(--text-primary)}.plan-price .period{font-size:var(--text-ll-size);color:var(--text-muted);align-self:flex-end;margin-bottom:12px;margin-left:4px}.plan-desc{font-size:14px;color:var(--text-secondary);line-height:1.5;min-height:44px}.divider-sm{height:1px;background:var(--card-border);margin-block:var(--sp-md)}.plan-features{list-style:none;display:flex;flex-direction:column;gap:var(--sp-sm);flex:1;margin-bottom:var(--sp-lg)}.plan-features li{font-size:14px;color:var(--text-secondary);display:flex;align-items:center;gap:12px}.plan-features li.excluded{color:var(--text-muted);text-decoration:line-through;opacity:.6}.feat-icon{display:flex;align-items:center;justify-content:center;width:18px;flex-shrink:0}.feat-icon svg{stroke-width:3px}.plan-features li:not(.excluded) .feat-icon{color:var(--accent)}.plan-features li.excluded .feat-icon{color:var(--text-muted)}.plan-btn{width:100%;padding:14px;border-radius:var(--r-base);font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.05em;text-align:center;transition:var(--transition)}.plan-btn.primary{background:var(--accent);color:var(--on-primary)}.plan-btn.outline{border:1px solid var(--card-border);color:var(--text-primary)}.plan-btn.outline:hover{border-color:var(--accent);background:#7cfc000d}.plan-footer{margin-top:var(--sp-xl);display:flex;justify-content:center}.footer-card{background:var(--surface-container);border:1px solid var(--card-border);border-radius:var(--r-xl);padding:var(--sp-xl) var(--sp-lg);text-align:center;max-width:700px;width:100%}.footer-title{font-family:var(--font-display);font-size:var(--text-hm-size);color:var(--text-primary);margin-bottom:var(--sp-sm)}.footer-title i{color:var(--accent);font-family:serif}.footer-desc{color:var(--text-secondary);margin-bottom:var(--sp-lg)}.footer-actions{display:flex;align-items:center;justify-content:center;gap:var(--sp-md)}.footer-actions .plan-btn{width:auto;min-width:200px}.link-back{color:var(--text-muted);font-size:var(--text-ll-size);transition:var(--transition);text-decoration:none}.link-back:hover{color:var(--text-primary);padding-left:-5px}@media (max-width: 768px){.footer-actions{flex-direction:column;gap:var(--sp-sm)}.footer-actions .plan-btn{width:100%}}.skills-section{display:flex;flex-direction:column;gap:var(--sp-lg);width:100%}.skills-header{text-align:center;width:100%}.skills-header .section-label{display:block;margin-bottom:var(--sp-sm)}.skills-title{font-family:var(--font-display);font-size:var(--text-hm-size);font-weight:var(--text-hm-weight);line-height:var(--text-hm-lh);letter-spacing:var(--text-hm-ls);color:var(--text-primary)}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--sp-md);width:100%}.skills-category-card{background:var(--surface-container-low);border:1px solid var(--card-border);border-radius:var(--r-lg);padding:var(--sp-md);transition:border-color var(--transition),box-shadow var(--transition),transform var(--transition)}.skills-category-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 0 16px var(--accent-glow)}.category-title{font-family:var(--font-display);font-size:var(--text-hs-size);font-weight:var(--text-hs-weight);color:var(--accent);margin-bottom:var(--sp-md);border-bottom:1px solid var(--card-border);padding-bottom:var(--sp-xs)}.skills-list{display:flex;flex-wrap:wrap;gap:var(--sp-xs) var(--sp-sm)}.skill-chip{font-family:var(--font-display);font-size:var(--text-lm-size);font-weight:var(--text-lm-weight);letter-spacing:var(--text-lm-ls);color:var(--text-secondary);background:var(--surface-container);border:1px solid var(--card-border);padding:4px 10px;border-radius:var(--r-sm);transition:var(--transition)}.skill-chip:hover{color:var(--text-primary);border-color:var(--accent);background:#6ee0000d}@media (max-width: 640px){.skills-grid{grid-template-columns:1fr}}.testimonials-section{display:flex;flex-direction:column;gap:var(--sp-lg);width:100%}.testimonials-header{text-align:center;width:100%}.testimonials-title{font-family:var(--font-display);font-size:var(--text-hm-size);color:var(--text-primary)}.testimonials-title i{color:var(--accent);font-family:serif;font-style:italic}.testimonials-slider{display:flex;flex-direction:column;gap:var(--sp-md);width:100%}.testimonials-controls{display:flex;justify-content:flex-end;gap:var(--sp-sm)}.testimonial-nav{width:44px;height:44px;border-radius:999px;border:1px solid var(--card-border);background:var(--surface-container-low);color:var(--text-primary);cursor:pointer;transition:var(--transition);display:inline-flex;align-items:center;justify-content:center;padding:0}.testimonial-nav-icon{font-size:1.1rem;line-height:1;font-weight:600}.testimonial-nav:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}.testimonial-nav:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.testimonial-card{background:var(--surface-container-low);border:1px solid var(--card-border);border-radius:var(--r-xl);padding:var(--sp-lg);display:flex;flex-direction:column;gap:var(--sp-md);position:relative;transition:var(--transition);min-height:260px}.testimonial-card:hover{transform:translateY(-4px);border-color:var(--accent);box-shadow:0 10px 30px #0000004d}.quote-icon{font-family:serif;font-size:5rem;line-height:1;color:var(--accent);opacity:.2;position:absolute;top:10px;left:var(--sp-md)}.testimonial-content{font-size:var(--text-bm-size);color:var(--text-secondary);line-height:1.7;position:relative;z-index:1;font-style:italic}.testimonial-footer{display:flex;align-items:center;gap:var(--sp-sm);margin-top:auto;border-top:1px solid var(--card-border);padding-top:var(--sp-md)}.testimonial-avatar{width:50px;height:50px;border-radius:var(--r-full);object-fit:cover;border:1px solid var(--card-border)}.testimonial-info{display:flex;flex-direction:column}.testimonial-name{font-family:var(--font-display);font-size:var(--text-bl-size);color:var(--text-primary);font-weight:600}.testimonial-role{font-size:var(--text-ll-size);color:var(--text-muted)}.testimonial-dots{display:flex;justify-content:center;gap:10px}.testimonial-dot{width:12px;height:12px;border-radius:999px;border:0;background:color-mix(in srgb,var(--text-muted) 45%,transparent);cursor:pointer;transition:var(--transition)}.testimonial-dot.is-active{width:32px;background:var(--accent)}@media (max-width: 640px){.testimonials-controls{justify-content:center}.testimonial-nav{width:40px;height:40px}.testimonial-nav-icon{font-size:1rem}.testimonial-card{padding:var(--sp-md);min-height:300px}}@layer theme,base,components,utilities;@layer theme{@theme default{ --font-sans: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"; --font-serif: ui-serif, Georgia, Cambria, "Times New Roman", Times, serif; --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; --color-red-50: oklch(97.1% .013 17.38); --color-red-100: oklch(93.6% .032 17.717); --color-red-200: oklch(88.5% .062 18.334); --color-red-300: oklch(80.8% .114 19.571); --color-red-400: oklch(70.4% .191 22.216); --color-red-500: oklch(63.7% .237 25.331); --color-red-600: oklch(57.7% .245 27.325); --color-red-700: oklch(50.5% .213 27.518); --color-red-800: oklch(44.4% .177 26.899); --color-red-900: oklch(39.6% .141 25.723); --color-red-950: oklch(25.8% .092 26.042); --color-orange-50: oklch(98% .016 73.684); --color-orange-100: oklch(95.4% .038 75.164); --color-orange-200: oklch(90.1% .076 70.697); --color-orange-300: oklch(83.7% .128 66.29); --color-orange-400: oklch(75% .183 55.934); --color-orange-500: oklch(70.5% .213 47.604); --color-orange-600: oklch(64.6% .222 41.116); --color-orange-700: oklch(55.3% .195 38.402); --color-orange-800: oklch(47% .157 37.304); --color-orange-900: oklch(40.8% .123 38.172); --color-orange-950: oklch(26.6% .079 36.259); --color-amber-50: oklch(98.7% .022 95.277); --color-amber-100: oklch(96.2% .059 95.617); --color-amber-200: oklch(92.4% .12 95.746); --color-amber-300: oklch(87.9% .169 91.605); --color-amber-400: oklch(82.8% .189 84.429); --color-amber-500: oklch(76.9% .188 70.08); --color-amber-600: oklch(66.6% .179 58.318); --color-amber-700: oklch(55.5% .163 48.998); --color-amber-800: oklch(47.3% .137 46.201); --color-amber-900: oklch(41.4% .112 45.904); --color-amber-950: oklch(27.9% .077 45.635); --color-yellow-50: oklch(98.7% .026 102.212); --color-yellow-100: oklch(97.3% .071 103.193); --color-yellow-200: oklch(94.5% .129 101.54); --color-yellow-300: oklch(90.5% .182 98.111); --color-yellow-400: oklch(85.2% .199 91.936); --color-yellow-500: oklch(79.5% .184 86.047); --color-yellow-600: oklch(68.1% .162 75.834); --color-yellow-700: oklch(55.4% .135 66.442); --color-yellow-800: oklch(47.6% .114 61.907); --color-yellow-900: oklch(42.1% .095 57.708); --color-yellow-950: oklch(28.6% .066 53.813); --color-lime-50: oklch(98.6% .031 120.757); --color-lime-100: oklch(96.7% .067 122.328); --color-lime-200: oklch(93.8% .127 124.321); --color-lime-300: oklch(89.7% .196 126.665); --color-lime-400: oklch(84.1% .238 128.85); --color-lime-500: oklch(76.8% .233 130.85); --color-lime-600: oklch(64.8% .2 131.684); --color-lime-700: oklch(53.2% .157 131.589); --color-lime-800: oklch(45.3% .124 130.933); --color-lime-900: oklch(40.5% .101 131.063); --color-lime-950: oklch(27.4% .072 132.109); --color-green-50: oklch(98.2% .018 155.826); --color-green-100: oklch(96.2% .044 156.743); --color-green-200: oklch(92.5% .084 155.995); --color-green-300: oklch(87.1% .15 154.449); --color-green-400: oklch(79.2% .209 151.711); --color-green-500: oklch(72.3% .219 149.579); --color-green-600: oklch(62.7% .194 149.214); --color-green-700: oklch(52.7% .154 150.069); --color-green-800: oklch(44.8% .119 151.328); --color-green-900: oklch(39.3% .095 152.535); --color-green-950: oklch(26.6% .065 152.934); --color-emerald-50: oklch(97.9% .021 166.113); --color-emerald-100: oklch(95% .052 163.051); --color-emerald-200: oklch(90.5% .093 164.15); --color-emerald-300: oklch(84.5% .143 164.978); --color-emerald-400: oklch(76.5% .177 163.223); --color-emerald-500: oklch(69.6% .17 162.48); --color-emerald-600: oklch(59.6% .145 163.225); --color-emerald-700: oklch(50.8% .118 165.612); --color-emerald-800: oklch(43.2% .095 166.913); --color-emerald-900: oklch(37.8% .077 168.94); --color-emerald-950: oklch(26.2% .051 172.552); --color-teal-50: oklch(98.4% .014 180.72); --color-teal-100: oklch(95.3% .051 180.801); --color-teal-200: oklch(91% .096 180.426); --color-teal-300: oklch(85.5% .138 181.071); --color-teal-400: oklch(77.7% .152 181.912); --color-teal-500: oklch(70.4% .14 182.503); --color-teal-600: oklch(60% .118 184.704); --color-teal-700: oklch(51.1% .096 186.391); --color-teal-800: oklch(43.7% .078 188.216); --color-teal-900: oklch(38.6% .063 188.416); --color-teal-950: oklch(27.7% .046 192.524); --color-cyan-50: oklch(98.4% .019 200.873); --color-cyan-100: oklch(95.6% .045 203.388); --color-cyan-200: oklch(91.7% .08 205.041); --color-cyan-300: oklch(86.5% .127 207.078); --color-cyan-400: oklch(78.9% .154 211.53); --color-cyan-500: oklch(71.5% .143 215.221); --color-cyan-600: oklch(60.9% .126 221.723); --color-cyan-700: oklch(52% .105 223.128); --color-cyan-800: oklch(45% .085 224.283); --color-cyan-900: oklch(39.8% .07 227.392); --color-cyan-950: oklch(30.2% .056 229.695); --color-sky-50: oklch(97.7% .013 236.62); --color-sky-100: oklch(95.1% .026 236.824); --color-sky-200: oklch(90.1% .058 230.902); --color-sky-300: oklch(82.8% .111 230.318); --color-sky-400: oklch(74.6% .16 232.661); --color-sky-500: oklch(68.5% .169 237.323); --color-sky-600: oklch(58.8% .158 241.966); --color-sky-700: oklch(50% .134 242.749); --color-sky-800: oklch(44.3% .11 240.79); --color-sky-900: oklch(39.1% .09 240.876); --color-sky-950: oklch(29.3% .066 243.157); --color-blue-50: oklch(97% .014 254.604); --color-blue-100: oklch(93.2% .032 255.585); --color-blue-200: oklch(88.2% .059 254.128); --color-blue-300: oklch(80.9% .105 251.813); --color-blue-400: oklch(70.7% .165 254.624); --color-blue-500: oklch(62.3% .214 259.815); --color-blue-600: oklch(54.6% .245 262.881); --color-blue-700: oklch(48.8% .243 264.376); --color-blue-800: oklch(42.4% .199 265.638); --color-blue-900: oklch(37.9% .146 265.522); --color-blue-950: oklch(28.2% .091 267.935); --color-indigo-50: oklch(96.2% .018 272.314); --color-indigo-100: oklch(93% .034 272.788); --color-indigo-200: oklch(87% .065 274.039); --color-indigo-300: oklch(78.5% .115 274.713); --color-indigo-400: oklch(67.3% .182 276.935); --color-indigo-500: oklch(58.5% .233 277.117); --color-indigo-600: oklch(51.1% .262 276.966); --color-indigo-700: oklch(45.7% .24 277.023); --color-indigo-800: oklch(39.8% .195 277.366); --color-indigo-900: oklch(35.9% .144 278.697); --color-indigo-950: oklch(25.7% .09 281.288); --color-violet-50: oklch(96.9% .016 293.756); --color-violet-100: oklch(94.3% .029 294.588); --color-violet-200: oklch(89.4% .057 293.283); --color-violet-300: oklch(81.1% .111 293.571); --color-violet-400: oklch(70.2% .183 293.541); --color-violet-500: oklch(60.6% .25 292.717); --color-violet-600: oklch(54.1% .281 293.009); --color-violet-700: oklch(49.1% .27 292.581); --color-violet-800: oklch(43.2% .232 292.759); --color-violet-900: oklch(38% .189 293.745); --color-violet-950: oklch(28.3% .141 291.089); --color-purple-50: oklch(97.7% .014 308.299); --color-purple-100: oklch(94.6% .033 307.174); --color-purple-200: oklch(90.2% .063 306.703); --color-purple-300: oklch(82.7% .119 306.383); --color-purple-400: oklch(71.4% .203 305.504); --color-purple-500: oklch(62.7% .265 303.9); --color-purple-600: oklch(55.8% .288 302.321); --color-purple-700: oklch(49.6% .265 301.924); --color-purple-800: oklch(43.8% .218 303.724); --color-purple-900: oklch(38.1% .176 304.987); --color-purple-950: oklch(29.1% .149 302.717); --color-fuchsia-50: oklch(97.7% .017 320.058); --color-fuchsia-100: oklch(95.2% .037 318.852); --color-fuchsia-200: oklch(90.3% .076 319.62); --color-fuchsia-300: oklch(83.3% .145 321.434); --color-fuchsia-400: oklch(74% .238 322.16); --color-fuchsia-500: oklch(66.7% .295 322.15); --color-fuchsia-600: oklch(59.1% .293 322.896); --color-fuchsia-700: oklch(51.8% .253 323.949); --color-fuchsia-800: oklch(45.2% .211 324.591); --color-fuchsia-900: oklch(40.1% .17 325.612); --color-fuchsia-950: oklch(29.3% .136 325.661); --color-pink-50: oklch(97.1% .014 343.198); --color-pink-100: oklch(94.8% .028 342.258); --color-pink-200: oklch(89.9% .061 343.231); --color-pink-300: oklch(82.3% .12 346.018); --color-pink-400: oklch(71.8% .202 349.761); --color-pink-500: oklch(65.6% .241 354.308); --color-pink-600: oklch(59.2% .249 .584); --color-pink-700: oklch(52.5% .223 3.958); --color-pink-800: oklch(45.9% .187 3.815); --color-pink-900: oklch(40.8% .153 2.432); --color-pink-950: oklch(28.4% .109 3.907); --color-rose-50: oklch(96.9% .015 12.422); --color-rose-100: oklch(94.1% .03 12.58); --color-rose-200: oklch(89.2% .058 10.001); --color-rose-300: oklch(81% .117 11.638); --color-rose-400: oklch(71.2% .194 13.428); --color-rose-500: oklch(64.5% .246 16.439); --color-rose-600: oklch(58.6% .253 17.585); --color-rose-700: oklch(51.4% .222 16.935); --color-rose-800: oklch(45.5% .188 13.697); --color-rose-900: oklch(41% .159 10.272); --color-rose-950: oklch(27.1% .105 12.094); --color-slate-50: oklch(98.4% .003 247.858); --color-slate-100: oklch(96.8% .007 247.896); --color-slate-200: oklch(92.9% .013 255.508); --color-slate-300: oklch(86.9% .022 252.894); --color-slate-400: oklch(70.4% .04 256.788); --color-slate-500: oklch(55.4% .046 257.417); --color-slate-600: oklch(44.6% .043 257.281); --color-slate-700: oklch(37.2% .044 257.287); --color-slate-800: oklch(27.9% .041 260.031); --color-slate-900: oklch(20.8% .042 265.755); --color-slate-950: oklch(12.9% .042 264.695); --color-gray-50: oklch(98.5% .002 247.839); --color-gray-100: oklch(96.7% .003 264.542); --color-gray-200: oklch(92.8% .006 264.531); --color-gray-300: oklch(87.2% .01 258.338); --color-gray-400: oklch(70.7% .022 261.325); --color-gray-500: oklch(55.1% .027 264.364); --color-gray-600: oklch(44.6% .03 256.802); --color-gray-700: oklch(37.3% .034 259.733); --color-gray-800: oklch(27.8% .033 256.848); --color-gray-900: oklch(21% .034 264.665); --color-gray-950: oklch(13% .028 261.692); --color-zinc-50: oklch(98.5% 0 0); --color-zinc-100: oklch(96.7% .001 286.375); --color-zinc-200: oklch(92% .004 286.32); --color-zinc-300: oklch(87.1% .006 286.286); --color-zinc-400: oklch(70.5% .015 286.067); --color-zinc-500: oklch(55.2% .016 285.938); --color-zinc-600: oklch(44.2% .017 285.786); --color-zinc-700: oklch(37% .013 285.805); --color-zinc-800: oklch(27.4% .006 286.033); --color-zinc-900: oklch(21% .006 285.885); --color-zinc-950: oklch(14.1% .005 285.823); --color-neutral-50: oklch(98.5% 0 0); --color-neutral-100: oklch(97% 0 0); --color-neutral-200: oklch(92.2% 0 0); --color-neutral-300: oklch(87% 0 0); --color-neutral-400: oklch(70.8% 0 0); --color-neutral-500: oklch(55.6% 0 0); --color-neutral-600: oklch(43.9% 0 0); --color-neutral-700: oklch(37.1% 0 0); --color-neutral-800: oklch(26.9% 0 0); --color-neutral-900: oklch(20.5% 0 0); --color-neutral-950: oklch(14.5% 0 0); --color-stone-50: oklch(98.5% .001 106.423); --color-stone-100: oklch(97% .001 106.424); --color-stone-200: oklch(92.3% .003 48.717); --color-stone-300: oklch(86.9% .005 56.366); --color-stone-400: oklch(70.9% .01 56.259); --color-stone-500: oklch(55.3% .013 58.071); --color-stone-600: oklch(44.4% .011 73.639); --color-stone-700: oklch(37.4% .01 67.558); --color-stone-800: oklch(26.8% .007 34.298); --color-stone-900: oklch(21.6% .006 56.043); --color-stone-950: oklch(14.7% .004 49.25); --color-mauve-50: oklch(98.5% 0 0); --color-mauve-100: oklch(96% .003 325.6); --color-mauve-200: oklch(92.2% .005 325.62); --color-mauve-300: oklch(86.5% .012 325.68); --color-mauve-400: oklch(71.1% .019 323.02); --color-mauve-500: oklch(54.2% .034 322.5); --color-mauve-600: oklch(43.5% .029 321.78); --color-mauve-700: oklch(36.4% .029 323.89); --color-mauve-800: oklch(26.3% .024 320.12); --color-mauve-900: oklch(21.2% .019 322.12); --color-mauve-950: oklch(14.5% .008 326); --color-olive-50: oklch(98.8% .003 106.5); --color-olive-100: oklch(96.6% .005 106.5); --color-olive-200: oklch(93% .007 106.5); --color-olive-300: oklch(88% .011 106.6); --color-olive-400: oklch(73.7% .021 106.9); --color-olive-500: oklch(58% .031 107.3); --color-olive-600: oklch(46.6% .025 107.3); --color-olive-700: oklch(39.4% .023 107.4); --color-olive-800: oklch(28.6% .016 107.4); --color-olive-900: oklch(22.8% .013 107.4); --color-olive-950: oklch(15.3% .006 107.1); --color-mist-50: oklch(98.7% .002 197.1); --color-mist-100: oklch(96.3% .002 197.1); --color-mist-200: oklch(92.5% .005 214.3); --color-mist-300: oklch(87.2% .007 219.6); --color-mist-400: oklch(72.3% .014 214.4); --color-mist-500: oklch(56% .021 213.5); --color-mist-600: oklch(45% .017 213.2); --color-mist-700: oklch(37.8% .015 216); --color-mist-800: oklch(27.5% .011 216.9); --color-mist-900: oklch(21.8% .008 223.9); --color-mist-950: oklch(14.8% .004 228.8); --color-taupe-50: oklch(98.6% .002 67.8); --color-taupe-100: oklch(96% .002 17.2); --color-taupe-200: oklch(92.2% .005 34.3); --color-taupe-300: oklch(86.8% .007 39.5); --color-taupe-400: oklch(71.4% .014 41.2); --color-taupe-500: oklch(54.7% .021 43.1); --color-taupe-600: oklch(43.8% .017 39.3); --color-taupe-700: oklch(36.7% .016 35.7); --color-taupe-800: oklch(26.8% .011 36.5); --color-taupe-900: oklch(21.4% .009 43.1); --color-taupe-950: oklch(14.7% .004 49.3); --color-black: #000; --color-white: #fff; --spacing: .25rem; --breakpoint-sm: 40rem; --breakpoint-md: 48rem; --breakpoint-lg: 64rem; --breakpoint-xl: 80rem; --breakpoint-2xl: 96rem; --container-3xs: 16rem; --container-2xs: 18rem; --container-xs: 20rem; --container-sm: 24rem; --container-md: 28rem; --container-lg: 32rem; --container-xl: 36rem; --container-2xl: 42rem; --container-3xl: 48rem; --container-4xl: 56rem; --container-5xl: 64rem; --container-6xl: 72rem; --container-7xl: 80rem; --text-xs: .75rem; --text-xs--line-height: calc(1 / .75); --text-sm: .875rem; --text-sm--line-height: calc(1.25 / .875); --text-base: 1rem; --text-base--line-height: 1.5 ; --text-lg: 1.125rem; --text-lg--line-height: calc(1.75 / 1.125); --text-xl: 1.25rem; --text-xl--line-height: calc(1.75 / 1.25); --text-2xl: 1.5rem; --text-2xl--line-height: calc(2 / 1.5); --text-3xl: 1.875rem; --text-3xl--line-height: 1.2 ; --text-4xl: 2.25rem; --text-4xl--line-height: calc(2.5 / 2.25); --text-5xl: 3rem; --text-5xl--line-height: 1; --text-6xl: 3.75rem; --text-6xl--line-height: 1; --text-7xl: 4.5rem; --text-7xl--line-height: 1; --text-8xl: 6rem; --text-8xl--line-height: 1; --text-9xl: 8rem; --text-9xl--line-height: 1; --font-weight-thin: 100; --font-weight-extralight: 200; --font-weight-light: 300; --font-weight-normal: 400; --font-weight-medium: 500; --font-weight-semibold: 600; --font-weight-bold: 700; --font-weight-extrabold: 800; --font-weight-black: 900; --tracking-tighter: -.05em; --tracking-tight: -.025em; --tracking-normal: 0em; --tracking-wide: .025em; --tracking-wider: .05em; --tracking-widest: .1em; --leading-tight: 1.25; --leading-snug: 1.375; --leading-normal: 1.5; --leading-relaxed: 1.625; --leading-loose: 2; --radius-xs: .125rem; --radius-sm: .25rem; --radius-md: .375rem; --radius-lg: .5rem; --radius-xl: .75rem; --radius-2xl: 1rem; --radius-3xl: 1.5rem; --radius-4xl: 2rem; --shadow-2xs: 0 1px rgb(0 0 0 / .05); --shadow-xs: 0 1px 2px 0 rgb(0 0 0 / .05); --shadow-sm: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1); --shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1); --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1); --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1); --shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / .25); --inset-shadow-2xs: inset 0 1px rgb(0 0 0 / .05); --inset-shadow-xs: inset 0 1px 1px rgb(0 0 0 / .05); --inset-shadow-sm: inset 0 2px 4px rgb(0 0 0 / .05); --drop-shadow-xs: 0 1px 1px rgb(0 0 0 / .05); --drop-shadow-sm: 0 1px 2px rgb(0 0 0 / .15); --drop-shadow-md: 0 3px 3px rgb(0 0 0 / .12); --drop-shadow-lg: 0 4px 4px rgb(0 0 0 / .15); --drop-shadow-xl: 0 9px 7px rgb(0 0 0 / .1); --drop-shadow-2xl: 0 25px 25px rgb(0 0 0 / .15); --text-shadow-2xs: 0px 1px 0px rgb(0 0 0 / .15); --text-shadow-xs: 0px 1px 1px rgb(0 0 0 / .2); --text-shadow-sm: 0px 1px 0px rgb(0 0 0 / .075), 0px 1px 1px rgb(0 0 0 / .075), 0px 2px 2px rgb(0 0 0 / .075); --text-shadow-md: 0px 1px 1px rgb(0 0 0 / .1), 0px 1px 2px rgb(0 0 0 / .1), 0px 2px 4px rgb(0 0 0 / .1); --text-shadow-lg: 0px 1px 2px rgb(0 0 0 / .1), 0px 3px 2px rgb(0 0 0 / .1), 0px 4px 8px rgb(0 0 0 / .1); --ease-in: cubic-bezier(.4, 0, 1, 1); --ease-out: cubic-bezier(0, 0, .2, 1); --ease-in-out: cubic-bezier(.4, 0, .2, 1); --animate-spin: spin 1s linear infinite; --animate-ping: ping 1s cubic-bezier(0, 0, .2, 1) infinite; --animate-pulse: pulse 2s cubic-bezier(.4, 0, .6, 1) infinite; --animate-bounce: bounce 1s infinite; @keyframes spin { to { transform: rotate(360deg); } } @keyframes ping { 75%, 100% { transform: scale(2); opacity: 0; } } @keyframes pulse { 50% { opacity: .5; } } @keyframes bounce { 0%, 100% { transform: translateY(-25%); animation-timing-function: cubic-bezier(.8, 0, 1, 1); } 50% { transform: none; animation-timing-function: cubic-bezier(0, 0, .2, 1); } } --blur-xs: 4px; --blur-sm: 8px; --blur-md: 12px; --blur-lg: 16px; --blur-xl: 24px; --blur-2xl: 40px; --blur-3xl: 64px; --perspective-dramatic: 100px; --perspective-near: 300px; --perspective-normal: 500px; --perspective-midrange: 800px; --perspective-distant: 1200px; --aspect-video: 16 / 9; --default-transition-duration: .15s; --default-transition-timing-function: cubic-bezier(.4, 0, .2, 1); --default-font-family: --theme(--font-sans, initial); --default-font-feature-settings: --theme( --font-sans--font-feature-settings, initial ); --default-font-variation-settings: --theme( --font-sans--font-variation-settings, initial ); --default-mono-font-family: --theme(--font-mono, initial); --default-mono-font-feature-settings: --theme( --font-mono--font-feature-settings, initial ); --default-mono-font-variation-settings: --theme( --font-mono--font-variation-settings, initial ); }@theme default inline reference{ --blur: 8px; --shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1); --shadow-inner: inset 0 2px 4px 0 rgb(0 0 0 / .05); --drop-shadow: 0 1px 2px rgb(0 0 0 / .1), 0 1px 1px rgb(0 0 0 / .06); --radius: .25rem; --max-width-prose: 65ch; }}@layer base{*,:after,:before,::backdrop,::file-selector-button{box-sizing:border-box;margin:0;padding:0;border:0 solid}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-family:--theme(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:--theme(--default-font-feature-settings,normal);font-variation-settings:--theme(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:--theme(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:--theme(--default-mono-font-feature-settings,normal);font-variation-settings:--theme(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea,::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;border-radius:0;background-color:transparent;opacity:1}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not (-webkit-appearance: -apple-pay-button)) or (contain-intrinsic-size: 1px){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit,::-webkit-datetime-edit-year-field,::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-second-field,::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]),::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer utilities{@tailwind utilities;}:root{--surface: #131313;--surface-dim: #131313;--surface-bright: #3a3939;--surface-container-lowest: #0e0e0e;--surface-container-low: #1c1b1b;--surface-container: #201f1f;--surface-container-high: #2a2a2a;--surface-container-highest: #353534;--surface-variant: #353534;--background: #131313;--on-surface: #e5e2e1;--on-surface-variant: #bdcbae;--on-background: #e5e2e1;--inverse-surface: #e5e2e1;--inverse-on-surface: #313030;--outline: #88957b;--outline-variant: #3e4a34;--primary: #f7ffe9;--on-primary: #173800;--primary-container: #7cfc00;--on-primary-container: #347000;--inverse-primary: #316b00;--surface-tint: #6ee000;--primary-fixed: #82ff1a;--primary-fixed-dim: #6ee000;--on-primary-fixed: #0a2000;--on-primary-fixed-variant: #245100;--secondary: #c7c6c6;--on-secondary: #2f3131;--secondary-container: #464747;--on-secondary-container: #b5b5b5;--tertiary: #fcfcfc;--on-tertiary: #2f3131;--tertiary-container: #dfdfdf;--on-tertiary-container: #616263;--error: #ffb4ab;--on-error: #690005;--error-container: #93000a;--on-error-container: #ffdad6;--bg: var(--background);--bg-alt: var(--surface-container-lowest);--card-bg: var(--surface-container-low);--card-border: rgba(136, 149, 123, .2);--card-border-hover: var(--outline);--text-primary: var(--on-surface);--text-secondary: var(--on-surface-variant);--text-muted: var(--outline);--accent: var(--primary-container);--accent-dim: var(--primary-fixed-dim);--accent-glow: rgba(110, 224, 0, .2);--font-display: "Space Grotesk", sans-serif;--font-body: "Inter", sans-serif;--text-hl-size: clamp(2rem, 5vw, 68px);--text-hl-weight: 700;--text-hl-lh: 1.1;--text-hl-ls: -.02em;--text-hm-size: clamp(1.5rem, 3vw, 52px);--text-hm-weight: 600;--text-hm-lh: 1.2;--text-hm-ls: -.01em;--text-hs-size: 24px;--text-hs-weight: 600;--text-hs-lh: 1.2;--text-bl-size: 18px;--text-bl-weight: 400;--text-bl-lh: 1.6;--text-bm-size: 20px;--text-bm-weight: 400;--text-bm-lh: 1.6;--text-ll-size: 14px;--text-ll-weight: 500;--text-ll-ls: .05em;--text-lm-size: 18px;--text-lm-weight: 500;--text-lm-ls: .05em;--r-sm: .125rem;--r-base: .25rem;--r-md: .375rem;--r-lg: .5rem;--r-xl: .75rem;--r-full: 9999px;--sp-xs: 4px;--sp-sm: 12px;--sp-md: 24px;--sp-lg: 48px;--sp-xl: 80px;--sp-gutter: 24px;--sp-margin: 32px;--transition: .2s ease;--transition-md: .35s ease}.light{--bg: #f8f8f6;--bg-alt: #efefeb;--card-bg: #ffffff;--card-border: rgba(62, 74, 52, .15);--card-border-hover: #3e4a34;--text-primary: #141412;--text-secondary: #4a4a40;--text-muted: #7d8573;--surface-container-low: #ffffff;--surface-container-lowest: #efefeb;--surface-container: #f4f4f0;--surface-container-high: #e9e9e4;--outline: #6c7564;--accent: #2d5a00;--accent-dim: #244a00;--accent-glow: rgba(45, 90, 0, .15);--on-primary: #ffffff}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;scroll-padding-top:80px;scrollbar-width:thin;scrollbar-color:var(--accent) var(--bg-alt)}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--accent);border-radius:var(--r-base)}body{font-family:var(--font-body);font-size:var(--text-bm-size);font-weight:var(--text-bm-weight);line-height:var(--text-bm-lh);background-color:var(--bg);color:var(--text-primary);transition:background-color var(--transition-md),color var(--transition-md);overflow-x:hidden}li{list-style:none}img{max-width:100%;display:block}a{color:inherit;text-decoration:none;transition:color var(--transition)}button{all:unset;cursor:pointer}button:disabled{opacity:.4;cursor:not-allowed}button:active:not(:disabled){transform:scale(.97)}.app{position:relative}.container{width:100%;max-width:1600px;margin-inline:auto;padding-inline:var(--sp-margin)}@media (max-width: 1024px){.container{padding-inline:var(--sp-md)}}@media (max-width: 640px){.container{padding-inline:var(--sp-sm)}}.flex{display:flex;align-items:center}.section-label{font-family:var(--font-display);font-size:var(--text-ll-size);font-weight:var(--text-ll-weight);letter-spacing:var(--text-ll-ls);text-transform:uppercase;color:var(--accent);display:block;margin-bottom:var(--sp-sm)}.section-title{font-family:var(--font-display);font-size:var(--text-hm-size);font-weight:var(--text-hm-weight);line-height:var(--text-hm-lh);letter-spacing:var(--text-hm-ls);color:var(--text-primary);margin-bottom:var(--sp-md)}.divider{width:100%;height:1px;background:var(--card-border);margin-block:var(--sp-xl)}.section-full>.container{padding-block:var(--sp-xl)}.section-full>.vertical-timeline-wrapper,#experience{padding-inline:var(--sp-margin)}.mode{position:fixed;bottom:var(--sp-md);right:var(--sp-md);width:40px;height:40px;border-radius:var(--r-base);background:var(--accent);color:var(--on-primary);font-size:1.1rem;display:flex;align-items:center;justify-content:center;z-index:999;transition:var(--transition);border:1px solid var(--accent-dim)}.mode:hover{box-shadow:0 0 12px var(--accent-glow);transform:scale(1.05)}.icon-sun{animation:spin 8s linear infinite;color:var(--on-primary)!important}@keyframes spin{to{transform:rotate(360deg)}}.scroll2Top{background:var(--surface-container-high);border:1px solid var(--card-border);width:40px;height:40px;border-radius:var(--r-base);position:fixed;bottom:calc(var(--sp-md) + 52px);right:var(--sp-md);display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--on-surface);z-index:998;transition:var(--transition)}.scroll2Top:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 0 10px var(--accent-glow)}.center-image{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.icon-image{width:65%;height:65%;object-fit:contain}.flex-col{flex-direction:column}
