.App{min-height:100dvh}.App,main{position:relative}main{z-index:1}.bg{inset:0;overflow:hidden;pointer-events:none;position:fixed;z-index:0}.bg-horizon{background:linear-gradient(90deg,#0000 5%,var(--accent) 40%,var(--accent-2) 60%,#0000 95%);box-shadow:0 0 80px 6px var(--glow);height:1px;opacity:.55;top:0;transform:translateX(-50%);width:140vw}.bg-aurora,.bg-horizon{left:50%;position:absolute}.bg-aurora{aspect-ratio:1;border-radius:50%;filter:blur(70px) saturate(1.2);margin-left:-80vmax;opacity:.16;top:-60vh;width:160vmax;will-change:transform}.bg-aurora-a{animation:aurora-spin 90s linear infinite;background:conic-gradient(from 210deg at 50% 50%,#0000 0deg,var(--accent-strong) 55deg,#0000 110deg,var(--accent-2) 200deg,#0000 260deg,var(--accent) 310deg,#0000 1turn)}.bg-aurora-b{animation:aurora-spin 140s linear infinite reverse;background:conic-gradient(from 30deg at 50% 50%,#0000 0deg,var(--accent-2) 80deg,#0000 160deg,var(--accent-strong) 250deg,#0000 330deg);opacity:.1;top:-70vh}@keyframes aurora-spin{to{transform:rotate(1turn)}}body.light .bg-aurora-a{opacity:.1}body.light .bg-aurora-b{opacity:.07}body.light .bg-horizon{opacity:.35}.bg-dots{background-image:radial-gradient(var(--border-strong) 1px,#0000 1.5px);background-size:26px 26px;mask-image:radial-gradient(ellipse 100% 65% at 50% 0,#000 10%,#0000 78%);-webkit-mask-image:radial-gradient(ellipse 100% 65% at 50% 0,#000 10%,#0000 78%);opacity:.5}.bg-dots,.bg-meteors{inset:0;position:absolute}.bg-meteor{animation:meteor 9s linear infinite;background:linear-gradient(180deg,#0000,var(--accent),#0000);height:110px;opacity:0;position:absolute;top:-8%;transform:rotate(38deg);width:1px}.bg-meteor:after{background:var(--accent);border-radius:50%;bottom:-2px;box-shadow:0 0 10px 2px var(--glow);content:"";height:4px;left:-1.5px;position:absolute;width:4px}.bg-meteor:first-child{animation-delay:2s;left:22%}.bg-meteor:nth-child(2){animation-delay:6.5s;animation-duration:11s;height:80px;left:58%}.bg-meteor:nth-child(3){animation-delay:10s;animation-duration:13s;height:130px;left:82%}@keyframes meteor{0%,74%{opacity:0;transform:rotate(38deg) translateY(0)}76%{opacity:.9}88%,to{opacity:0;transform:rotate(38deg) translateY(64vh)}}body.light .bg-meteor{display:none}.bg-spotlight{background:radial-gradient(520px circle at 50vw -20vh,var(--glow),#0000 72%);background:radial-gradient(520px circle at var(--mx,50vw) var(--my,-20vh),var(--glow),#0000 72%);inset:0;opacity:0;position:absolute;transition:opacity .6s ease}body.light .bg-spotlight{background:radial-gradient(520px circle at 50vw -20vh,#2563eb17,#0000 72%);background:radial-gradient(520px circle at var(--mx,50vw) var(--my,-20vh),#2563eb17,#0000 72%)}.bg-grain{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='a'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23a)'/%3E%3C/svg%3E");background-size:160px 160px;inset:0;opacity:.05;position:absolute}body.light .bg-grain{opacity:.035}@media (prefers-reduced-motion:reduce){.bg-aurora,.bg-meteor{animation:none}.bg-meteor,.bg-spotlight{display:none}}.navbar{border-bottom:1px solid #0000;left:0;position:fixed;right:0;top:0;transition:background-color var(--dur-med) ease,border-color var(--dur-med) ease;z-index:100}.navbar-scrolled{backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);background:var(--nav-bg);border-bottom-color:var(--border)}.navbar-inner{align-items:center;display:flex;gap:16px;height:var(--nav-height);justify-content:space-between;margin:0 auto;max-width:var(--container);padding:0 24px}.logo{align-items:center;color:var(--text);display:inline-flex;font-weight:700;gap:10px}.logo-mark{background:var(--gradient);border-radius:10px;box-shadow:0 4px 14px var(--glow);color:#fff;display:grid;font-size:.8rem;font-weight:800;height:36px;letter-spacing:.04em;place-items:center;width:36px}.logo-name{font-size:1rem;letter-spacing:-.01em}.nav-links{align-items:center;display:flex;gap:4px;list-style:none;margin:0;padding:0}.nav-links a{border-radius:var(--radius-sm);color:var(--text-muted);display:inline-block;font-size:.92rem;font-weight:500;padding:10px 14px;position:relative;transition:color var(--dur-fast) ease}.nav-links a:after{background:var(--gradient);border-radius:2px;bottom:4px;content:"";height:2px;left:14px;position:absolute;right:14px;transform:scaleX(0);transform-origin:left;transition:transform var(--dur-med) var(--ease-out)}.nav-links a.active,.nav-links a:hover{color:var(--text)}.nav-links a.active:after{transform:scaleX(1)}.nav-actions{align-items:center;display:flex;gap:6px}.icon-btn{background:#0000;border:1px solid #0000;border-radius:var(--radius-sm);color:var(--text);display:grid;height:44px;place-items:center;transition:background-color var(--dur-fast) ease,border-color var(--dur-fast) ease,transform var(--dur-fast) var(--ease-out);width:44px}.icon-btn:hover{background:var(--surface-2);border-color:var(--border)}.icon-btn:active{transform:scale(.94)}.toggle-icons{display:grid;height:20px;place-items:center;position:relative;width:20px}.toggle-icons svg{inset:0;position:absolute;transition:opacity var(--dur-med) ease,transform var(--dur-med) var(--ease-out)}.toggle-icons.is-dark .toggle-sun{opacity:1;transform:rotate(0deg) scale(1)}.toggle-icons.is-dark .toggle-moon{opacity:0;transform:rotate(90deg) scale(.5)}.toggle-icons.is-light .toggle-sun{opacity:0;transform:rotate(-90deg) scale(.5)}.toggle-icons.is-light .toggle-moon{opacity:1;transform:rotate(0deg) scale(1)}.menu-toggle{display:none}.scroll-progress{background:var(--gradient);bottom:-1px;height:2px;left:0;position:absolute;right:0;transform:scaleX(0);transform-origin:left}.mobile-menu{display:none}@media (max-width:860px){.nav-links{display:none}.menu-toggle{display:grid}.logo-name{font-size:.95rem}.mobile-menu{background:var(--bg);bottom:0;display:block;left:0;opacity:0;padding:32px 24px;position:fixed;right:0;top:var(--nav-height);transform:translateY(-12px);transition:opacity var(--dur-med) var(--ease-out),transform var(--dur-med) var(--ease-out),visibility 0s linear var(--dur-med);visibility:hidden}.mobile-menu.open{opacity:1;transform:translateY(0);transition:opacity var(--dur-med) var(--ease-out),transform var(--dur-med) var(--ease-out);visibility:visible}.mobile-menu ul{display:flex;flex-direction:column;list-style:none;margin:0;padding:0}.mobile-menu li{opacity:0;transform:translateY(14px);transition:opacity var(--dur-med) var(--ease-out),transform var(--dur-med) var(--ease-out);transition-delay:0ms}.mobile-menu.open li{opacity:1;transform:translateY(0);transition-delay:calc(60ms + var(--i)*45ms)}.mobile-menu a{align-items:baseline;border-bottom:1px solid var(--border);color:var(--text);display:flex;font-size:1.4rem;font-weight:600;gap:16px;padding:18px 8px}.mobile-menu a.active,.mobile-menu-index{color:var(--accent)}.mobile-menu-index{font-family:var(--font-mono);font-size:.8rem}}.hero{display:flex;flex-direction:column;justify-content:center;min-height:100dvh;padding:calc(var(--nav-height) + 24px) 24px 48px;position:relative}.hero-inner{grid-gap:48px;align-items:center;display:grid;gap:48px;grid-template-columns:1.25fr .75fr;margin:0 auto;max-width:var(--container);width:100%}.hero-badge{align-items:center;background:var(--surface);border:1px solid var(--border-strong);border-radius:999px;color:var(--text-muted);display:inline-flex;font-size:.82rem;font-weight:500;gap:8px;margin-bottom:24px;padding:6px 14px}.hero-badge-dot{animation:pulse-dot 2s ease-in-out infinite;background:var(--success);border-radius:50%;height:8px;width:8px}@keyframes pulse-dot{0%,to{box-shadow:0 0 0 0 #4ade8080}50%{box-shadow:0 0 0 5px #4ade8000}}.hero-title{font-size:clamp(2.4rem,6vw,4rem);font-weight:800;letter-spacing:-.03em;line-height:1.08}.hero-name{background:var(--gradient);-webkit-background-clip:text;background-clip:text;color:#0000}.hero-role{align-items:center;color:var(--accent);display:flex;font-family:var(--font-mono);font-size:clamp(1.05rem,2.5vw,1.4rem);font-weight:500;margin-top:14px;min-height:2.2rem}.hero-caret{animation:blink 1.1s steps(1) infinite;background:var(--accent);height:1.3em;margin-left:4px;width:2px}@keyframes blink{50%{opacity:0}}.hero-desc{color:var(--text-muted);font-size:1.06rem;margin-top:20px;max-width:520px}.hero-buttons{gap:14px;margin-top:32px}.hero-buttons,.hero-meta{display:flex;flex-wrap:wrap}.hero-meta{align-items:center;gap:16px;margin-top:36px}.hero-location{align-items:center;color:var(--text-faint);display:inline-flex;font-size:.88rem;gap:6px}.hero-meta-divider{background:var(--border-strong);height:20px;width:1px}.hero-socials{display:flex;gap:4px}.hero-socials a{border-radius:var(--radius-sm);color:var(--text-muted);display:grid;height:44px;place-items:center;transition:color var(--dur-fast) ease,background-color var(--dur-fast) ease,transform var(--dur-fast) var(--ease-out);width:44px}.hero-socials a:hover{background:var(--accent-soft);color:var(--accent);transform:translateY(-2px)}.hero-visual{display:grid;place-items:center;position:relative}.hero-portrait{animation:float 6s ease-in-out infinite;aspect-ratio:1;background:var(--gradient);border-radius:50%;box-shadow:0 0 60px var(--glow);padding:5px;position:relative;width:min(300px,70vw)}.hero-portrait img{border:5px solid var(--bg);border-radius:50%;height:100%;object-fit:cover;width:100%}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-14px)}}.hero-orbit{animation:spin 30s linear infinite;aspect-ratio:1;border:1px dashed var(--border-strong);border-radius:50%;position:absolute;width:min(380px,88vw)}.hero-orbit:before{background:var(--accent);border-radius:50%;box-shadow:0 0 12px var(--glow);content:"";height:10px;left:50%;position:absolute;top:-5px;width:10px}@keyframes spin{to{transform:rotate(1turn)}}.hero-scroll-cue{animation:bob 2.2s ease-in-out infinite;border:1px solid var(--border-strong);border-radius:50%;bottom:28px;color:var(--text-muted);display:grid;height:44px;left:50%;place-items:center;position:absolute;transform:translateX(-50%);transition:color var(--dur-fast) ease,border-color var(--dur-fast) ease;width:44px}.hero-scroll-cue:hover{border-color:var(--accent);color:var(--accent)}@keyframes bob{0%,to{transform:translate(-50%)}50%{transform:translate(-50%,8px)}}@media (prefers-reduced-motion:reduce){.hero-badge-dot,.hero-caret,.hero-orbit,.hero-portrait,.hero-scroll-cue{animation:none}}@media (max-width:900px){.hero-inner{gap:40px;grid-template-columns:1fr;text-align:center}.hero-visual{margin-top:8px;order:-1}.hero-portrait{width:min(220px,55vw)}.hero-orbit{width:min(280px,72vw)}.hero-desc{margin-left:auto;margin-right:auto}.hero-buttons,.hero-meta,.hero-role{justify-content:center}.hero-scroll-cue{display:none}}.about-grid{grid-gap:56px;align-items:start;display:grid;gap:56px;grid-template-columns:1fr 1.1fr}.about-text p{color:var(--text-muted);font-size:1.05rem;line-height:1.75}.about-text p+p{margin-top:18px}.about-cta{color:var(--accent);display:inline-block;font-size:.95rem;font-weight:600;margin-top:28px;transition:transform var(--dur-fast) var(--ease-out)}.about-cta:hover{transform:translateY(2px)}.about-cards{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(2,1fr)}.about-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-card);padding:24px;transition:transform var(--dur-med) var(--ease-out),border-color var(--dur-med) ease}.about-card:hover{border-color:var(--border-strong);transform:translateY(-4px)}.about-card-icon{background:var(--accent-soft);border-radius:var(--radius-sm);color:var(--accent);display:grid;height:42px;margin-bottom:14px;place-items:center;width:42px}.about-card h3{font-size:1rem;font-weight:600;margin-bottom:8px}.about-card p{color:var(--text-muted);font-size:.88rem;line-height:1.6}@media (max-width:900px){.about-grid{gap:40px;grid-template-columns:1fr}}@media (max-width:560px){.about-cards{grid-template-columns:1fr}}.timeline{max-width:760px;padding-left:8px;position:relative}.timeline:before{background:linear-gradient(to bottom,var(--accent),var(--accent-2),#0000);bottom:6px;content:"";left:19px;opacity:.35;position:absolute;top:6px;width:2px}.timeline-item{display:flex;gap:24px;padding-bottom:40px;position:relative}.timeline-item:last-child{padding-bottom:0}.timeline-marker{display:flex;flex:0 0 24px;justify-content:center;position:relative}.timeline-dot{background:var(--bg);border:3px solid var(--accent);border-radius:50%;height:14px;margin-top:6px;position:relative;transition:transform var(--dur-fast) var(--ease-out);width:14px;z-index:1}.timeline-dot.is-current{animation:ping 2.4s var(--ease-out) infinite;background:var(--accent);box-shadow:0 0 0 0 var(--glow)}@keyframes ping{0%{box-shadow:0 0 0 0 var(--glow)}70%{box-shadow:0 0 0 10px #0000}to{box-shadow:0 0 0 0 #0000}}.timeline-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-card);flex:1 1;padding:22px 24px;transition:transform var(--dur-med) var(--ease-out),border-color var(--dur-med) ease}.timeline-item:hover .timeline-card{border-color:var(--border-strong);transform:translateX(6px)}.timeline-item:hover .timeline-dot{transform:scale(1.25)}.timeline-card-head{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.timeline-card h3{font-size:1.08rem;font-weight:600;letter-spacing:-.01em}.timeline-now{background:color-mix(in srgb,var(--success) 12%,#0000);border-radius:999px;color:var(--success);font-size:.7rem;font-weight:600;letter-spacing:.06em;padding:2px 10px;text-transform:uppercase}.timeline-company{color:var(--accent);font-size:.92rem;font-weight:500;margin-top:4px}.timeline-time{color:var(--text-faint);font-family:var(--font-mono);font-size:.78rem;margin-top:2px}.timeline-desc{color:var(--text-muted);font-size:.94rem;line-height:1.65;margin-top:12px}@media (prefers-reduced-motion:reduce){.timeline-dot.is-current{animation:none}}@media (max-width:560px){.timeline{padding-left:0}.timeline:before{left:11px}.timeline-item{gap:16px}.timeline-card{padding:18px}}.project-filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:36px}.filter-btn{align-items:center;background:#0000;border:1px solid var(--border-strong);border-radius:999px;color:var(--text-muted);display:inline-flex;font-size:.88rem;font-weight:500;gap:8px;min-height:44px;padding:0 18px;touch-action:manipulation;transition:color var(--dur-fast) ease,border-color var(--dur-fast) ease,background-color var(--dur-fast) ease,transform var(--dur-fast) var(--ease-out)}.filter-btn:hover{border-color:var(--accent);color:var(--text)}.filter-btn:active{transform:scale(.96)}.filter-btn.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.filter-count{font-family:var(--font-mono);font-size:.7rem;opacity:.7}.project-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.project-card{align-items:flex-start;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-card);color:var(--text);display:flex;flex-direction:column;font:inherit;gap:12px;padding:26px;text-align:left;transition:transform var(--dur-med) var(--ease-out),border-color var(--dur-med) ease,box-shadow var(--dur-med) var(--ease-out)}.project-card:hover{border-color:var(--accent);box-shadow:0 12px 32px var(--glow);transform:translateY(-6px)}.project-card-top{align-items:center;display:flex;justify-content:space-between;width:100%}.project-category{color:var(--text-faint);font-family:var(--font-mono);font-size:.72rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase}.project-featured{color:var(--accent);font-size:.72rem;font-weight:600}.project-card h3{font-size:1.14rem;font-weight:600;letter-spacing:-.01em}.project-desc{color:var(--text-muted);font-size:.92rem;line-height:1.6}.project-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto}.project-more{color:var(--accent);font-size:.85rem;font-weight:600;opacity:0;transform:translateX(-6px);transition:opacity var(--dur-med) var(--ease-out),transform var(--dur-med) var(--ease-out)}.project-card:focus-visible .project-more,.project-card:hover .project-more{opacity:1;transform:translateX(0)}.projects-actions{display:flex;justify-content:center;margin-top:40px}.modal-overlay{animation:overlay-in var(--dur-med) ease both;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);background:var(--scrim);display:grid;inset:0;padding:20px;place-items:center;position:fixed;z-index:200}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.modal{animation:modal-in .34s var(--ease-out) both;background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-pop);max-height:min(84dvh,800px);overflow-y:auto;padding:36px;position:relative;width:min(680px,100%)}@keyframes modal-in{0%{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-close{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);display:grid;height:44px;place-items:center;position:absolute;right:16px;top:16px;transition:border-color var(--dur-fast) ease,color var(--dur-fast) ease,transform var(--dur-fast) var(--ease-out);width:44px}.modal-close:hover{border-color:var(--danger);color:var(--danger)}.modal-close:active{transform:scale(.94)}.modal-title{font-size:1.5rem;font-weight:700;letter-spacing:-.02em;margin-top:8px;padding-right:48px}.modal-tags{margin-top:14px}.modal-details{color:var(--text-muted);font-size:.98rem;line-height:1.7;margin-top:18px}.modal-images,.modal-link{margin-top:24px}.modal-images{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.modal-images img{aspect-ratio:16/10;border:1px solid var(--border);border-radius:var(--radius-sm);object-fit:cover;transition:transform var(--dur-med) var(--ease-out);width:100%}.modal-images img:hover{transform:scale(1.03)}.modal-videos{margin-top:24px}.modal-videos video{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%}@media (prefers-reduced-motion:reduce){.modal,.modal-overlay{animation:none}}@media (max-width:560px){.project-grid{grid-template-columns:1fr}.modal{padding:24px 20px}}.skills-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(2,1fr)}.skill-group{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-card);padding:28px;transition:transform var(--dur-med) var(--ease-out),border-color var(--dur-med) ease}.skill-group:hover{border-color:var(--border-strong);transform:translateY(-4px)}.skill-group-head{align-items:center;display:flex;gap:12px;margin-bottom:18px}.skill-group-icon{background:var(--accent-soft);border-radius:var(--radius-sm);color:var(--accent);display:grid;height:40px;place-items:center;width:40px}.skill-group h3{font-size:1.05rem;font-weight:600}.skill-chips{display:flex;flex-wrap:wrap;gap:8px}.skill-chip{background:var(--surface-2);border:1px solid var(--border);border-radius:999px;color:var(--text-muted);cursor:default;font-size:.85rem;font-weight:500;padding:7px 14px;transition:color var(--dur-fast) ease,border-color var(--dur-fast) ease,background-color var(--dur-fast) ease,transform var(--dur-fast) var(--ease-out)}.skill-chip:hover{background:var(--accent-soft);border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}@media (max-width:760px){.skills-grid{grid-template-columns:1fr}.skill-group{padding:22px}}.contact-content{grid-gap:40px;align-items:start;display:grid;gap:40px;grid-template-columns:.8fr 1.2fr}.contact-info{display:flex;flex-direction:column;gap:14px}.contact-item{align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);display:flex;gap:16px;padding:18px 20px;transition:transform var(--dur-med) var(--ease-out),border-color var(--dur-med) ease}.contact-item:hover{border-color:var(--accent);transform:translateX(6px)}.contact-icon{background:var(--accent-soft);border-radius:var(--radius-sm);color:var(--accent);display:grid;flex-shrink:0;height:46px;place-items:center;width:46px}.contact-text{display:flex;flex-direction:column;min-width:0}.contact-label{color:var(--text-faint);font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase}.contact-value{color:var(--text);font-size:.95rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.contact-item:hover .contact-value{color:var(--accent)}.contact-form-container{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:32px}.contact-form{display:flex;flex-direction:column;gap:20px}.form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{color:var(--text);font-size:.85rem;font-weight:600}.form-group input,.form-group textarea{background:var(--bg-soft);border:1px solid var(--border-strong);border-radius:var(--radius-sm);color:var(--text);font-family:inherit;font-size:1rem;min-height:48px;padding:12px 16px;transition:border-color var(--dur-fast) ease,box-shadow var(--dur-fast) ease;width:100%}.form-group textarea{min-height:130px;resize:vertical}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-faint)}.form-group input:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);outline:none}.submit-btn{align-self:flex-start;min-width:180px}.submit-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-spinner{animation:spinner .7s linear infinite;border:2px solid #ffffff59;border-radius:50%;border-top-color:#fff;height:16px;width:16px}@keyframes spinner{to{transform:rotate(1turn)}}.form-error{background:color-mix(in srgb,var(--danger) 10%,#0000);border:1px solid color-mix(in srgb,var(--danger) 30%,#0000);border-radius:var(--radius-sm);color:var(--danger);font-size:.9rem;padding:12px 16px}.form-success{align-items:center;color:var(--success);display:flex;flex-direction:column;gap:16px;padding:48px 24px;text-align:center}.form-success p{color:var(--text);font-size:1.05rem}@media (max-width:860px){.contact-content{grid-template-columns:1fr}.contact-info{flex-direction:row;flex-wrap:wrap}.contact-item{flex:1 1 240px}}@media (max-width:560px){.form-row{grid-template-columns:1fr}.contact-form-container{padding:22px}.submit-btn{align-self:stretch;width:100%}}.footer{background:var(--bg-soft);border-top:1px solid var(--border);position:relative;z-index:1}.footer-inner{align-items:center;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;margin:0 auto;max-width:var(--container);padding:28px 24px}.footer-left{display:flex;flex-direction:column}.footer-name{color:var(--text);font-weight:700}.footer-note{color:var(--text-faint);font-size:.82rem}.footer-socials{display:flex;gap:4px}.footer-socials a{border-radius:var(--radius-sm);color:var(--text-muted);display:grid;height:44px;place-items:center;transition:color var(--dur-fast) ease,background-color var(--dur-fast) ease,transform var(--dur-fast) var(--ease-out);width:44px}.footer-socials a:hover{background:var(--accent-soft);color:var(--accent);transform:translateY(-2px)}.footer-top{align-items:center;border:1px solid var(--border-strong);border-radius:var(--radius-sm);color:var(--text-muted);display:inline-flex;font-size:.88rem;font-weight:500;gap:8px;min-height:44px;padding:0 18px;transition:color var(--dur-fast) ease,border-color var(--dur-fast) ease,transform var(--dur-fast) var(--ease-out)}.footer-top:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}@media (max-width:560px){.footer-inner{flex-direction:column;text-align:center}.footer-left{align-items:center}}.loader-wrapper{align-items:center;background:var(--bg);display:flex;flex-direction:column;gap:28px;inset:0;justify-content:center;position:fixed;z-index:999}.loader-mark{display:flex;font-size:2.6rem;font-weight:800;gap:2px;letter-spacing:-.02em}.loader-mark span{animation:rise .9s var(--ease-out) both;background:var(--gradient);-webkit-background-clip:text;background-clip:text;color:#0000}.loader-mark span:nth-child(2){animation-delay:.12s}@keyframes rise{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.loader-bar{background:var(--surface-2);border-radius:3px;height:3px;overflow:hidden;width:160px}.loader-bar-fill{animation:fill 1.3s var(--ease-in-out) both;background:var(--gradient);border-radius:3px;height:100%;transform-origin:left}@keyframes fill{0%{transform:scaleX(0)}to{transform:scaleX(1)}}@media (prefers-reduced-motion:reduce){.loader-bar-fill,.loader-mark span{animation:none}}:root{--bg:#09090b;--bg-soft:#0e0e11;--surface:#131316;--surface-2:#1a1a1f;--text:#fafafa;--text-muted:#a1a1aa;--text-faint:#71717a;--border:#ffffff14;--border-strong:#ffffff29;--accent:#60a5fa;--accent-strong:#3b82f6;--accent-2:#a78bfa;--accent-soft:#60a5fa1f;--gradient:linear-gradient(135deg,#60a5fa,#a78bfa);--success:#4ade80;--danger:#f87171;--glow:#60a5fa40;--scrim:#000000a6;--nav-bg:#09090bb8;--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-mono:"JetBrains Mono",Menlo,Consolas,monospace;--radius-sm:8px;--radius-md:14px;--radius-lg:20px;--shadow-card:0 1px 2px #0000004d,0 8px 24px #00000040;--shadow-pop:0 12px 40px #00000073;--ease-out:cubic-bezier(0.22,1,0.36,1);--ease-in-out:cubic-bezier(0.65,0,0.35,1);--dur-fast:180ms;--dur-med:300ms;--dur-slow:600ms;--container:1120px;--nav-height:68px}body.light{--bg:#fafafa;--bg-soft:#f4f4f5;--surface:#fff;--surface-2:#f4f4f5;--text:#18181b;--text-muted:#52525b;--text-faint:#71717a;--border:#00000014;--border-strong:#00000029;--accent:#2563eb;--accent-strong:#1d4ed8;--accent-2:#7c3aed;--accent-soft:#2563eb14;--gradient:linear-gradient(135deg,#2563eb,#7c3aed);--success:#16a34a;--danger:#dc2626;--glow:#2563eb26;--scrim:#18181b80;--nav-bg:#fafafac7;--shadow-card:0 1px 2px #0000000d,0 8px 24px #0000000f;--shadow-pop:0 12px 40px #00000024}*,:after,:before{box-sizing:border-box}html{overflow-x:hidden;overflow-x:clip;scroll-behavior:smooth;scroll-padding-top:80px;scroll-padding-top:calc(var(--nav-height) + 12px)}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#09090b;background-color:var(--bg);color:#fafafa;color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-family:var(--font-sans);font-size:16px;line-height:1.6;margin:0;overflow-x:hidden;transition:background-color .3s ease,color .3s ease;transition:background-color var(--dur-med) ease,color var(--dur-med) ease}img,video{display:block;max-width:100%}h1,h2,h3,h4,p{margin:0}a{color:#60a5fa;color:var(--accent);text-decoration:none}button{cursor:pointer;font-family:inherit}:focus-visible{border-radius:4px;outline:2px solid #60a5fa;outline:2px solid var(--accent);outline-offset:3px}::selection{background:#3b82f6;background:var(--accent-strong);color:#fff}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:#09090b;background:var(--bg)}::-webkit-scrollbar-thumb{background:#1a1a1f;background:var(--surface-2);border:2px solid #09090b;border:2px solid var(--bg);border-radius:8px}::-webkit-scrollbar-thumb:hover{background:#71717a;background:var(--text-faint)}.section{margin:0 auto;max-width:1120px;max-width:var(--container);padding:104px 24px;position:relative}.section-head{margin-bottom:48px}.section-kicker{align-items:center;color:#60a5fa;color:var(--accent);display:inline-flex;font-family:JetBrains Mono,Menlo,Consolas,monospace;font-family:var(--font-mono);font-size:.8rem;font-weight:500;gap:10px;letter-spacing:.12em;margin-bottom:12px;text-transform:uppercase}.section-kicker:before{background:#60a5fa;background:var(--accent);content:"";height:1px;width:28px}.section-title{font-size:clamp(1.8rem,4vw,2.6rem);font-weight:700;letter-spacing:-.02em;line-height:1.15}.section-sub{color:#a1a1aa;color:var(--text-muted);font-size:1.02rem;margin-top:12px;max-width:560px}.reveal{opacity:0;transform:translateY(28px);transition:opacity .6s cubic-bezier(.22,1,.36,1),transform .6s cubic-bezier(.22,1,.36,1);transition:opacity var(--dur-slow) var(--ease-out),transform var(--dur-slow) var(--ease-out);transition-delay:0ms;transition-delay:var(--reveal-delay,0ms);will-change:opacity,transform}.reveal-left{transform:translateX(-36px)}.reveal-right{transform:translateX(36px)}.reveal-scale{transform:scale(.94)}.reveal.visible{opacity:1;transform:none}.btn{align-items:center;border:1px solid #0000;border-radius:14px;border-radius:var(--radius-md);display:inline-flex;font-size:.95rem;font-weight:600;gap:8px;justify-content:center;letter-spacing:.01em;min-height:48px;padding:0 26px;touch-action:manipulation;transition:transform .18s cubic-bezier(.22,1,.36,1),box-shadow .3s cubic-bezier(.22,1,.36,1),background-color .18s ease,border-color .18s ease,color .18s ease;transition:transform var(--dur-fast) var(--ease-out),box-shadow var(--dur-med) var(--ease-out),background-color var(--dur-fast) ease,border-color var(--dur-fast) ease,color var(--dur-fast) ease;-webkit-user-select:none;user-select:none}.btn:active{transform:scale(.97)}.btn-primary{background:linear-gradient(135deg,#60a5fa,#a78bfa);background:var(--gradient);box-shadow:0 4px 20px #60a5fa40;box-shadow:0 4px 20px var(--glow);color:#fff}.btn-primary:hover{box-shadow:0 8px 28px #60a5fa40;box-shadow:0 8px 28px var(--glow);color:#fff;transform:translateY(-2px)}.btn-ghost{background:#0000;border-color:#ffffff29;border-color:var(--border-strong);color:#fafafa;color:var(--text)}.btn-ghost:hover{border-color:#60a5fa;border-color:var(--accent);transform:translateY(-2px)}.btn-ghost:hover,.tag{color:#60a5fa;color:var(--accent)}.tag{align-items:center;background:#60a5fa1f;background:var(--accent-soft);border:1px solid #0000;border-radius:999px;display:inline-flex;font-family:JetBrains Mono,Menlo,Consolas,monospace;font-family:var(--font-mono);font-size:.72rem;font-weight:500;padding:4px 12px;white-space:nowrap}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.reveal,.reveal-left,.reveal-right,.reveal-scale{opacity:1;transform:none}}@media (max-width:640px){.section{padding:72px 20px}.section-head{margin-bottom:36px}}
/*# sourceMappingURL=main.fde49b90.css.map*/