body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0e27;--bg-soft:#0f1437;--surface:#10183073;--surface-hover:#14203ea6;--surface-strong:#0c142de0;--text:#f0f4ff;--text-soft:#9daacc;--muted:#6b7f9f;--border:#ffffff14;--accent-1:#00d9ff;--accent-2:#0ea5e9;--accent-3:#c084fc;--gradient:linear-gradient(135deg,#0ea5e9,#00d9ff 50%,#06b6d4);--gradient-text:linear-gradient(135deg,#38bdf8,#00d9ff 50%,#06b6d4);--gradient-alt:linear-gradient(135deg,#c084fc,#a78bfa);--radius-sm:10px;--radius:16px;--radius-lg:24px;--shadow:0 20px 40px #00000059;--shadow-md:0 12px 24px #00000040;--shadow-glow:0 0 40px #00d9ff14;--shadow-focus:0 0 32px #0ea5e91f;--ease:cubic-bezier(0.34,1.56,0.64,1);--ease-in:cubic-bezier(0.42,0,1,1);--ease-out:cubic-bezier(0,0,0.58,1);--t:0.35s cubic-bezier(0.34,1.56,0.64,1);--t-slow:0.55s cubic-bezier(0.34,1.56,0.64,1);--t-fast:0.2s cubic-bezier(0.34,1.56,0.64,1)}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{background:#0a0e27;background:var(--bg);color:#f0f4ff;color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;font-weight:400;letter-spacing:.3px;line-height:1.6;margin-top:40px;overflow-x:hidden}a{color:inherit;text-decoration:none}.portfolio-page{background:radial-gradient(ellipse 85% 50% at 5% 5%,#0ea5e914 0,#0000 52%),radial-gradient(ellipse 70% 45% at 95% 15%,#00d9ff0d 0,#0000 58%),radial-gradient(ellipse 60% 55% at 50% 100%,#c084fc08 0,#0000 65%),linear-gradient(180deg,#08092a,#0a0e27 35%,#0a0e27 65%,#080a24);min-height:100vh;overflow:hidden;position:relative}.background-grid{animation:gridMove 24s linear infinite;background-image:linear-gradient(rgba(14,165,233,.024) 1px,#0000 0),linear-gradient(90deg,rgba(14,165,233,.024) 1px,#0000 0);background-size:52px 52px;inset:0;-webkit-mask-image:linear-gradient(180deg,#ffffff80 0,#0000);mask-image:linear-gradient(180deg,#ffffff80 0,#0000)}.background-glow,.background-grid{pointer-events:none;position:fixed;z-index:0}.background-glow{border-radius:50%;filter:blur(120px);will-change:transform}.glow-1{animation:floatGlow 14s ease-in-out infinite;background:radial-gradient(circle,#0ea5e91f,#0000 65%);height:580px;left:2%;top:50px;width:580px}.glow-2{animation:floatGlow 16s ease-in-out infinite reverse;animation-delay:-6s;background:radial-gradient(circle,#00d9ff14,#0000 68%);height:680px;right:-4%;top:160px;width:680px}.footer,.navbar,.section{position:relative;z-index:2}.navbar{align-items:center;animation:slideDown .8s cubic-bezier(.34,1.56,.64,1) both;animation:slideDown .8s var(--ease) both;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);background:#0a0e27bf;border-bottom:1px solid #ffffff14;border-bottom:1px solid var(--border);box-shadow:0 4px 16px #0003;display:flex;height:72px;justify-content:space-between;left:0;padding:0 52px;position:fixed;top:0;width:100%;z-index:1000}.logo{color:#f0f4ff;color:var(--text);font-size:1.6rem;font-weight:800;letter-spacing:-.03em;transition:opacity .2s cubic-bezier(.34,1.56,.64,1),transform .2s cubic-bezier(.34,1.56,.64,1);transition:opacity var(--t-fast),transform var(--t-fast)}.logo:hover{opacity:.85;transform:scale(1.02)}.logo span{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#38bdf8,#00d9ff 50%,#06b6d4);background:var(--gradient-text);-webkit-background-clip:text;background-clip:text;filter:drop-shadow(0 0 14px rgba(0,217,255,.3))}.nav-links{align-items:center;display:flex;gap:6px}.nav-links a{border-radius:10px;border-radius:var(--radius-sm);color:#9daacc;color:var(--text-soft);font-size:.87rem;font-weight:500;letter-spacing:.4px;padding:10px 16px;position:relative;transition:color .2s cubic-bezier(.34,1.56,.64,1),background .2s cubic-bezier(.34,1.56,.64,1);transition:color var(--t-fast),background var(--t-fast)}.nav-links a:after{background:linear-gradient(135deg,#0ea5e9,#00d9ff 50%,#06b6d4);background:var(--gradient);border-radius:2px;bottom:6px;content:"";height:2px;left:50%;position:absolute;transform:translateX(-50%);transition:width .2s cubic-bezier(.34,1.56,.64,1);transition:width var(--t-fast);width:0}.nav-links a:hover{background:#00d9ff14;color:#00d9ff;color:var(--accent-1)}.nav-links a:hover:after{width:50%}.section{margin:0 auto;max-width:1280px;padding:120px 28px}@supports (animation-timeline:view()){.fade-section{animation-timeline:view();animation-range:entry 8% cover 32%;animation:revealSection .9s cubic-bezier(.34,1.56,.64,1) both;animation:revealSection .9s var(--ease) both;opacity:0;transform:translateY(42px) scale(.98)}.fade-section .about-image-wrap,.fade-section .about-text,.fade-section .contact-form,.fade-section .contact-info,.fade-section .project-card,.fade-section .section-label,.fade-section .section-subtitle,.fade-section .section-title,.fade-section .skill-card,.fade-section .timeline-item{animation-timeline:view();animation-range:entry 6% cover 28%;animation:revealItem .8s cubic-bezier(.34,1.56,.64,1) both;animation:revealItem .8s var(--ease) both;animation-delay:0ms;animation-delay:calc(var(--reveal-order, 0)*80ms);opacity:0;transform:translateY(30px)}.fade-section .section-label{--reveal-order:0}.fade-section .section-title{--reveal-order:1}.fade-section .section-subtitle{--reveal-order:2}.fade-section .about-text,.fade-section .contact-info{--reveal-order:3}.fade-section .about-image-wrap,.fade-section .contact-form{--reveal-order:4}.fade-section .project-card:first-child,.fade-section .skill-card:first-child,.fade-section .timeline-item:first-child{--reveal-order:3}.fade-section .project-card:nth-child(2),.fade-section .skill-card:nth-child(2),.fade-section .timeline-item:nth-child(2){--reveal-order:4}.fade-section .project-card:nth-child(3),.fade-section .skill-card:nth-child(3),.fade-section .timeline-item:nth-child(3){--reveal-order:5}.fade-section .project-card:nth-child(4),.fade-section .skill-card:nth-child(4),.fade-section .timeline-item:nth-child(4){--reveal-order:6}.fade-section .project-card:nth-child(5),.fade-section .skill-card:nth-child(5),.fade-section .timeline-item:nth-child(5){--reveal-order:7}.fade-section .project-card:nth-child(6),.fade-section .skill-card:nth-child(6),.fade-section .timeline-item:nth-child(6){--reveal-order:8}.fade-section .timeline-item{transform:translateX(-28px)}}.hero{display:flex;flex-direction:column;gap:24px;justify-content:center;min-height:96vh;padding-top:80px;text-align:center}.hero,.hero-badge{align-items:center}.hero-badge{animation:pulseBadge 3.2s ease-in-out infinite,slideUp .8s cubic-bezier(.34,1.56,.64,1) both;animation:pulseBadge 3.2s ease-in-out infinite,slideUp .8s var(--ease) both;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#00d9ff0f;border:1px solid #00d9ff40;border-radius:999px;color:#00d9ff;color:var(--accent-1);display:inline-flex;font-size:.75rem;font-weight:700;gap:10px;letter-spacing:.1em;padding:11px 26px;text-transform:uppercase}.hero-badge:before{animation:blink 2.6s ease-in-out infinite;background:#00d9ff;background:var(--accent-1);border-radius:50%;box-shadow:0 0 10px #00d9ff;box-shadow:0 0 10px var(--accent-1);content:"";flex-shrink:0;height:8px;width:8px}.hero h1{animation:slideUp .9s cubic-bezier(.34,1.56,.64,1) both;animation:slideUp .9s var(--ease) both;animation-delay:.1s;font-size:clamp(3.6rem,9vw,7.4rem);font-weight:900;letter-spacing:-.035em;line-height:.92}.hero h1 span{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#38bdf8,#00d9ff 50%,#06b6d4);background:var(--gradient-text);-webkit-background-clip:text;background-clip:text;filter:drop-shadow(0 0 28px rgba(0,217,255,.25))}.hero h2{animation:slideUp .9s cubic-bezier(.34,1.56,.64,1) both;animation:slideUp .9s var(--ease) both;animation-delay:.2s;color:#9daacc;color:var(--text-soft);font-size:clamp(1.15rem,3vw,2.1rem);font-weight:300;letter-spacing:.4px}.hero p{animation:slideUp .9s cubic-bezier(.34,1.56,.64,1) both;animation:slideUp .9s var(--ease) both;animation-delay:.3s;color:#6b7f9f;color:var(--muted);font-size:clamp(1rem,1.9vw,1.15rem);line-height:1.9;max-width:640px}.hero-buttons{animation:slideUp .9s cubic-bezier(.34,1.56,.64,1) both;animation:slideUp .9s var(--ease) both;animation-delay:.4s;display:flex;gap:16px;margin-top:12px}.btn{align-items:center;border:none;border-radius:999px;cursor:pointer;display:inline-flex;font-size:.92rem;font-weight:600;gap:8px;justify-content:center;letter-spacing:.3px;overflow:hidden;padding:15px 36px;position:relative;transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s cubic-bezier(.34,1.56,.64,1),border-color .2s cubic-bezier(.34,1.56,.64,1),background .2s cubic-bezier(.34,1.56,.64,1);transition:transform var(--t-fast),box-shadow var(--t-fast),border-color var(--t-fast),background var(--t-fast)}.btn:before{background:#fff0;border-radius:inherit;content:"";inset:0;pointer-events:none;position:absolute;transition:background .2s cubic-bezier(.34,1.56,.64,1);transition:background var(--t-fast)}.btn:hover:before{background:#ffffff14}.btn:hover{transform:translateY(-4px) scale(1.02)}.btn:active{transform:translateY(-1px) scale(.99)}.btn-primary{background:linear-gradient(135deg,#0ea5e9,#00d9ff 50%,#06b6d4);background:var(--gradient);box-shadow:0 8px 32px #00d9ff47,0 0 16px #0ea5e924;color:#030a15;font-weight:700}.btn-primary:hover{box-shadow:0 16px 48px #00d9ff5c,0 0 32px #0ea5e933}.btn-secondary{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#00d9ff0d;border:1.5px solid #00d9ff40;color:#00d9ff;color:var(--accent-1)}.btn-secondary:hover{background:#00d9ff14;border-color:#00d9ff73;box-shadow:0 8px 28px #00d9ff1a}.social-icons{animation:slideUp .9s cubic-bezier(.34,1.56,.64,1) both;animation:slideUp .9s var(--ease) both;animation-delay:.5s;display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:20px}.social-icons.left{animation:none;justify-content:flex-start;margin-top:0}.social-icons a{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#00d9ff0d;border:1.5px solid #00d9ff33;border-radius:50%;color:#9daacc;color:var(--text-soft);display:flex;font-size:1.1rem;height:50px;justify-content:center;transition:transform .2s cubic-bezier(.34,1.56,.64,1),border-color .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s cubic-bezier(.34,1.56,.64,1),color .2s cubic-bezier(.34,1.56,.64,1),background .2s cubic-bezier(.34,1.56,.64,1);transition:transform var(--t-fast),border-color var(--t-fast),box-shadow var(--t-fast),color var(--t-fast),background var(--t-fast);width:50px}.social-icons a:hover{background:#00d9ff1a;border-color:#00d9ff73;box-shadow:0 10px 32px #00d9ff26,0 0 0 5px #00d9ff0f;color:#00d9ff;color:var(--accent-1);transform:translateY(-6px) scale(1.08)}.section-label{color:#00d9ff;color:var(--accent-1);font-size:.72rem;font-weight:700;letter-spacing:.12em;margin-bottom:16px;text-transform:uppercase}.section-title{font-size:clamp(2.4rem,5vw,4.2rem);font-weight:900;letter-spacing:-.03em;line-height:1.05;margin-bottom:18px}.section-subtitle{color:#9daacc;color:var(--text-soft);font-size:1.08rem;line-height:1.78;margin-bottom:54px;max-width:550px}.center{text-align:center}.center.section-subtitle,.section-subtitle.center{margin-left:auto;margin-right:auto}.about{grid-gap:80px;align-items:center;display:grid;gap:80px;grid-template-columns:1.1fr .9fr}.about-text h2{font-size:clamp(2.4rem,5.5vw,4.8rem);font-weight:900;letter-spacing:-.03em;line-height:1.02;margin-bottom:32px}.about-text h2 span{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#38bdf8,#00d9ff 50%,#06b6d4);background:var(--gradient-text);-webkit-background-clip:text;background-clip:text}.about-text p{color:#9daacc;color:var(--text-soft);font-size:1.08rem;line-height:1.96;margin-bottom:20px}.about-image-wrap{animation:floatCard 8s ease-in-out infinite;background:linear-gradient(135deg,#0ea5e94d,#00d9ff26,#c084fc1a);border-radius:24px;border-radius:var(--radius-lg);box-shadow:0 20px 40px #00000059,0 0 40px #00d9ff14;box-shadow:var(--shadow),var(--shadow-glow);padding:4px;position:relative}.about-image{border-radius:20px;border-radius:calc(var(--radius-lg) - 4px);display:block;min-height:460px;object-fit:cover;width:100%}.stats{display:flex;flex-wrap:wrap;gap:48px;margin-top:40px}.stats h3{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#38bdf8,#00d9ff 50%,#06b6d4);background:var(--gradient-text);-webkit-background-clip:text;background-clip:text;font-size:2.8rem;font-weight:900;letter-spacing:-.04em;line-height:1;margin-bottom:6px}.stats span{color:#6b7f9f;color:var(--muted);font-size:.87rem;font-weight:600;letter-spacing:.05em}.contact-form,.info-card,.project-card,.skill-card,.timeline-card{backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);background:#10183073;background:var(--surface);border:1px solid #ffffff14;border:1px solid var(--border)}.projects-grid,.skills-grid{grid-gap:24px;display:grid;gap:24px}.projects-grid,.skills-grid{grid-template-columns:repeat(3,1fr)}.skill-card{animation:fadeUpSoft .8s cubic-bezier(.34,1.56,.64,1) both;animation:fadeUpSoft .8s var(--ease) both;border-radius:16px;border-radius:var(--radius);overflow:hidden;padding:36px 32px;position:relative;transition:transform .35s cubic-bezier(.34,1.56,.64,1),border-color .35s cubic-bezier(.34,1.56,.64,1),box-shadow .35s cubic-bezier(.34,1.56,.64,1),background .35s cubic-bezier(.34,1.56,.64,1);transition:transform var(--t),border-color var(--t),box-shadow var(--t),background var(--t)}.skill-card:before{background:radial-gradient(ellipse at top left,#00d9ff0f,#0000 68%);content:"";inset:0;opacity:0;pointer-events:none;position:absolute;transition:opacity .35s cubic-bezier(.34,1.56,.64,1);transition:opacity var(--t)}.skill-card:hover{background:#14203ea6;background:var(--surface-hover);border-color:#00d9ff38;box-shadow:0 32px 72px #0006,0 0 0 1px #00d9ff1a,0 0 40px #00d9ff14;box-shadow:0 32px 72px #0006,0 0 0 1px #00d9ff1a,var(--shadow-glow);transform:translateY(-12px)}.skill-card:hover:before{opacity:1}.skill-icon{align-items:center;background:#00d9ff14;border:1px solid #00d9ff26;border-radius:14px;color:#00d9ff;color:var(--accent-1);display:flex;font-family:Courier New,monospace;font-size:1.3rem;font-weight:700;height:62px;justify-content:center;margin-bottom:26px;transition:transform .35s cubic-bezier(.34,1.56,.64,1),box-shadow .35s cubic-bezier(.34,1.56,.64,1),background .35s cubic-bezier(.34,1.56,.64,1);transition:transform var(--t),box-shadow var(--t),background var(--t);width:62px}.skill-card:hover .skill-icon{background:#00d9ff24;box-shadow:0 0 32px #00d9ff33;transform:rotate(-6deg) scale(1.12)}.skill-card h3{color:#f0f4ff;color:var(--text);font-size:1.24rem;font-weight:700;letter-spacing:-.02em;margin-bottom:12px}.skill-card p{color:#9daacc;color:var(--text-soft);font-size:.96rem;line-height:1.8}.project-card{border-radius:16px;border-radius:var(--radius);overflow:hidden;transition:transform .35s cubic-bezier(.34,1.56,.64,1),border-color .35s cubic-bezier(.34,1.56,.64,1),box-shadow .35s cubic-bezier(.34,1.56,.64,1);transition:transform var(--t),border-color var(--t),box-shadow var(--t)}.project-card:hover{border-color:#00d9ff38;box-shadow:0 36px 72px #0000006b,0 0 40px #00d9ff14;box-shadow:0 36px 72px #0000006b,var(--shadow-glow);transform:translateY(-12px)}.project-image{display:block;height:240px;object-fit:cover;transition:transform .55s cubic-bezier(.34,1.56,.64,1);transition:transform var(--t-slow);width:100%}.project-card:hover .project-image{transform:scale(1.08)}.project-content{padding:28px;position:relative}.project-content:before{background:linear-gradient(90deg,#0000,#ffffff0f,#0000);content:"";height:1px;left:28px;position:absolute;right:28px;top:0}.project-content h3{color:#f0f4ff;color:var(--text);font-size:1.24rem;font-weight:700;letter-spacing:-.02em;margin-bottom:10px}.project-content p{color:#9daacc;color:var(--text-soft);font-size:.94rem;line-height:1.75;margin-bottom:20px}.project-tags{display:flex;flex-wrap:wrap;gap:8px}.project-tags span{background:#00d9ff0d;border:1px solid #00d9ff33;border-radius:999px;color:#00d9ff;color:var(--accent-1);font-size:.69rem;font-weight:700;letter-spacing:.04em;padding:6px 13px;transition:background .2s cubic-bezier(.34,1.56,.64,1),border-color .2s cubic-bezier(.34,1.56,.64,1);transition:background var(--t-fast),border-color var(--t-fast)}.project-card:hover .project-tags span{background:#00d9ff1a;border-color:#00d9ff59}.project-links{display:flex;gap:20px}.project-links a{color:#00d9ff;color:var(--accent-1);font-size:.92rem;font-weight:600;transition:opacity .2s cubic-bezier(.34,1.56,.64,1),transform .2s cubic-bezier(.34,1.56,.64,1);transition:opacity var(--t-fast),transform var(--t-fast)}.project-links a:hover{opacity:.75;transform:translateX(4px)}.timeline{margin:0 auto;max-width:860px;padding-left:40px;position:relative}.timeline:before{background:linear-gradient(180deg,#0000,#00d9ff99 10%,#00d9ff4d 85%,#0000);content:"";height:100%;left:10px;position:absolute;top:0;width:2px}.timeline-item{margin-bottom:32px;position:relative}.timeline-dot{animation:pulseDot 2.8s ease-in-out infinite;background:linear-gradient(135deg,#0ea5e9,#00d9ff 50%,#06b6d4);background:var(--gradient);border-radius:50%;box-shadow:0 0 0 5px #00d9ff1f,0 0 26px #00d9ff73;height:20px;left:-40px;position:absolute;top:30px;width:20px}.timeline-card{border-radius:16px;border-radius:var(--radius);overflow:hidden;padding:32px;position:relative;transition:transform .35s cubic-bezier(.34,1.56,.64,1),box-shadow .35s cubic-bezier(.34,1.56,.64,1),border-color .35s cubic-bezier(.34,1.56,.64,1),background .35s cubic-bezier(.34,1.56,.64,1);transition:transform var(--t),box-shadow var(--t),border-color var(--t),background var(--t)}.timeline-card:before{background:linear-gradient(135deg,#0ea5e9,#00d9ff 50%,#06b6d4);background:var(--gradient);bottom:0;content:"";left:0;opacity:0;position:absolute;top:0;transition:opacity .35s cubic-bezier(.34,1.56,.64,1);transition:opacity var(--t);width:3px}.timeline-card:hover{background:#14203ea6;background:var(--surface-hover);border-color:#00d9ff33;box-shadow:0 20px 56px #00000059,0 0 40px #00d9ff0f;transform:translateX(10px)}.timeline-card:hover:before{opacity:1}.timeline-top{align-items:flex-start;display:flex;gap:16px;justify-content:space-between;margin-bottom:18px}.timeline-top h3{color:#f0f4ff;color:var(--text);font-size:1.2rem;font-weight:700;letter-spacing:-.02em;margin-bottom:6px}.timeline-top h4{color:#00d9ff;color:var(--accent-1);font-size:.89rem;font-weight:700;letter-spacing:.02em}.timeline-top span{background:#ffffff0a;border:1px solid #ffffff14;border:1px solid var(--border);border-radius:999px;color:#6b7f9f;color:var(--muted);flex-shrink:0;font-size:.83rem;font-weight:600;padding:5px 14px;white-space:nowrap}.timeline-card p{color:#9daacc;color:var(--text-soft);font-size:.97rem;line-height:1.86}.contact-sub{margin-left:auto;margin-right:auto;max-width:520px}.contact-grid{grid-gap:48px;align-items:start;display:grid;gap:48px;grid-template-columns:1fr 1.3fr;margin-top:60px}.contact-info h3{color:#f0f4ff;color:var(--text);font-size:1.54rem;font-weight:700;letter-spacing:-.03em;margin-bottom:24px}.contact-info h4{color:#9daacc;color:var(--text-soft);font-size:.94rem;font-weight:700;letter-spacing:.02em;margin-bottom:18px;margin-top:32px;text-transform:uppercase}.info-card{border-radius:10px;border-radius:var(--radius-sm);margin-bottom:14px;padding:22px 24px;transition:transform .2s cubic-bezier(.34,1.56,.64,1),border-color .2s cubic-bezier(.34,1.56,.64,1),background .2s cubic-bezier(.34,1.56,.64,1);transition:transform var(--t-fast),border-color var(--t-fast),background var(--t-fast)}.info-card:hover{background:#14203ea6;background:var(--surface-hover);border-color:#00d9ff33;transform:translateY(-5px)}.info-card strong{color:#6b7f9f;color:var(--muted);display:block;font-size:.71rem;font-weight:700;letter-spacing:.12em;margin-bottom:8px;text-transform:uppercase}.info-card p{color:#f0f4ff;color:var(--text);font-size:1.1rem;font-weight:500}.contact-note{color:#9daacc;color:var(--text-soft);font-size:.95rem;line-height:1.86;margin-top:24px}.contact-form{animation:fadeUpSoft .9s cubic-bezier(.34,1.56,.64,1) both;animation:fadeUpSoft .9s var(--ease) both;border-radius:16px;border-radius:var(--radius);box-shadow:0 20px 40px #00000059,inset 0 1px 0 #ffffff0d;box-shadow:var(--shadow),inset 0 1px 0 #ffffff0d;padding:36px}.contact-form label{color:#9daacc;color:var(--text-soft);display:block;font-size:.88rem;font-weight:700;letter-spacing:.03em;margin-bottom:10px}.contact-form input,.contact-form textarea{background:#00d9ff08;border:1px solid #ffffff14;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius-sm);color:#f0f4ff;color:var(--text);font-family:inherit;font-size:.95rem;margin-bottom:22px;outline:none;padding:15px 18px;resize:vertical;transition:border-color .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s cubic-bezier(.34,1.56,.64,1),background .2s cubic-bezier(.34,1.56,.64,1);transition:border-color var(--t-fast),box-shadow var(--t-fast),background var(--t-fast);width:100%}.contact-form input::placeholder,.contact-form textarea::placeholder{color:#6b7f9f;color:var(--muted)}.contact-form input:focus,.contact-form textarea:focus{background:#00d9ff0a;border-color:#00d9ff59;box-shadow:0 0 0 5px #00d9ff12}.full{border:none;cursor:pointer;font-family:inherit;width:100%}.footer{border-top:1px solid #ffffff14;border-top:1px solid var(--border);color:#6b7f9f;color:var(--muted);font-size:.88rem;letter-spacing:.3px;margin-top:40px;padding:40px 20px;text-align:center}@keyframes slideDown{0%{opacity:0;transform:translateY(-24px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeUpSoft{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes revealSection{0%{opacity:0;transform:translateY(42px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes revealItem{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes floatGlow{0%,to{opacity:.75;transform:translateY(0) scale(1)}50%{opacity:1;transform:translateY(-32px) scale(1.08)}}@keyframes floatCard{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}@keyframes pulseBadge{0%,to{box-shadow:0 0 0 #00d9ff00}50%{box-shadow:0 0 36px #00d9ff1f}}@keyframes pulseDot{0%,to{box-shadow:0 0 0 5px #00d9ff1a,0 0 20px #00d9ff59}50%{box-shadow:0 0 0 7px #00d9ff2e,0 0 36px #00d9ff99}}@keyframes gridMove{0%{transform:translateY(0)}to{transform:translateY(52px)}}@keyframes blink{0%,to{opacity:1}50%{opacity:.32}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}.fade-section,.fade-section .about-image-wrap,.fade-section .about-text,.fade-section .contact-form,.fade-section .contact-info,.fade-section .project-card,.fade-section .section-label,.fade-section .section-subtitle,.fade-section .section-title,.fade-section .skill-card,.fade-section .timeline-item{opacity:1!important;transform:none!important}}@media (max-width:1100px){.about,.contact-grid{grid-template-columns:1fr 1fr}.projects-grid,.skills-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){body{margin-top:0}.section{padding:96px 20px}.navbar{flex-direction:row;gap:0;height:64px;padding:0 20px}.logo{font-size:1.4rem}.hero{gap:20px;min-height:auto;padding-top:100px}.about,.contact-grid,.projects-grid,.skills-grid{grid-template-columns:1fr}.hero-buttons{align-items:center;flex-direction:column;max-width:300px;width:100%}.btn{width:100%}.timeline-top{flex-direction:column;gap:10px}.timeline-top span{align-self:flex-start}.stats{gap:32px}.project-image{height:210px}.contact-form{padding:28px}}@media (max-width:480px){.hero h1{font-size:clamp(3rem,14vw,3.8rem)}.section-title{font-size:clamp(2.1rem,10vw,3rem)}.about-text h2{font-size:clamp(2.1rem,10vw,3.2rem)}.section{padding:80px 16px}.navbar{padding:0 16px}.contact-grid{gap:32px}}.menu-toggle{background:#0000;border:none;border-radius:10px;border-radius:var(--radius-sm);color:#f0f4ff;color:var(--text);cursor:pointer;display:none;font-size:1.4rem;padding:8px;transition:background .2s cubic-bezier(.34,1.56,.64,1),color .2s cubic-bezier(.34,1.56,.64,1);transition:background var(--t-fast),color var(--t-fast);z-index:1100}.menu-toggle:hover{background:#00d9ff14;color:#00d9ff;color:var(--accent-1)}@media (max-width:768px){.menu-toggle{align-items:center;display:flex;justify-content:center}.nav-links{backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);background:#0a0e27f2;border:1px solid #00d9ff26;border-radius:16px;border-radius:var(--radius);box-shadow:0 32px 64px #0009,0 0 0 1px #00d9ff14;flex-direction:column;gap:4px;opacity:0;overflow:hidden;padding:12px;position:absolute;right:16px;top:calc(100% + 10px);transform:translateY(-12px) scale(.96);transition:opacity .28s cubic-bezier(.34,1.56,.64,1),transform .28s cubic-bezier(.34,1.56,.64,1),visibility .28s;transition:opacity .28s var(--ease),transform .28s var(--ease),visibility .28s;visibility:hidden;width:220px}.nav-links.active{opacity:1;transform:translateY(0) scale(1);visibility:visible}.nav-links a{border-radius:10px;border-radius:var(--radius-sm);font-size:.92rem;padding:14px 16px;width:100%}.nav-links a:after{display:none}.hero{padding-top:128px}}
/*# sourceMappingURL=main.fbaac65b.css.map*/