*,:after,:before{box-sizing:border-box}body,html{height:100%}body{margin:0;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,Helvetica Neue,Arial,Apple Color Emoji,Segoe UI Emoji;background:var(--bg);color:var(--text)}:root{--bg:#0b0b0c;--text:#f0f0f3;--muted:#9aa0a6;--accent:#8b5cf6;--accent-2:#22d3ee;--card:#101014;--panel-border:hsla(0,0%,100%,.08);--panel-bg-start:hsla(0,0%,100%,.06);--panel-bg-end:hsla(0,0%,100%,.02);--nav-bg:rgba(11,11,12,.5)}[data-theme=light]{--bg:#eceff3;--text:#0b0b0c;--muted:#5f6368;--card:#f7f8fa;--panel-border:rgba(0,0,0,.08);--panel-bg-start:rgba(0,0,0,.04);--panel-bg-end:rgba(0,0,0,.01);--nav-bg:hsla(0,0%,100%,.7)}html{scroll-behavior:smooth}.container{width:min(1120px,92%);margin:0 auto}.section{padding:45px 0;position:relative}@media (max-width:900px){.section{padding:22px 0}}.bg-stage{inset:0;overflow:hidden;pointer-events:none;filter:saturate(1.1)}.bg-stage,.blob{position:absolute}.blob{width:60vmax;height:60vmax;border-radius:50%;filter:blur(60px);opacity:.6;mix-blend-mode:screen}.blob.violet{background:radial-gradient(closest-side,rgba(139,92,246,.9),rgba(139,92,246,0))}.blob.cyan{background:radial-gradient(closest-side,rgba(34,211,238,.9),rgba(34,211,238,0))}.blob.amber{background:radial-gradient(closest-side,rgba(245,158,11,.8),rgba(245,158,11,0))}@keyframes float-a{0%{transform:translate(-20%,-10%) scale(1)}50%{transform:translate(10%) scale(1.1)}to{transform:translate(-20%,-10%) scale(1)}}@keyframes float-b{0%{transform:translate(40%,10%) scale(1.1)}50%{transform:translateY(-10%) scale(.95)}to{transform:translate(40%,10%) scale(1.1)}}@keyframes float-c{0%{transform:translate(-10%,40%) scale(1.05)}50%{transform:translate(10%,20%) scale(1.15)}to{transform:translate(-10%,40%) scale(1.05)}}.blob.a{animation:float-a 22s ease-in-out infinite}.blob.b{animation:float-b 28s ease-in-out infinite}.blob.c{animation:float-c 26s ease-in-out infinite}.cursor-glow{position:fixed;width:var(--cursor-size,225px);height:var(--cursor-size,225px);border-radius:50%;pointer-events:none;background:radial-gradient(closest-side,rgba(139,92,246,.18),rgba(34,211,238,0));transform:translate(-50%,-50%);mix-blend-mode:screen;z-index:2;transition:opacity .55s ease-in}[data-theme=light] .cursor-glow{background:radial-gradient(closest-side,rgba(139,92,246,.28),rgba(34,211,238,0));mix-blend-mode:multiply}@media (pointer:coarse){.cursor-glow{display:none!important}}nav.sticky{position:-webkit-sticky;position:sticky;top:0;z-index:10;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:var(--nav-bg);border-bottom:1px solid var(--panel-border)}nav .bar{display:flex;align-items:center;justify-content:space-between;height:64px}nav a{color:var(--text);text-decoration:none}nav .links a{color:var(--muted);margin-left:20px;font-size:14px;transition:color .2s ease}nav .links a:hover{color:var(--text)}nav .brand{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60vw}.menu-btn{display:none;width:40px;height:34px;border-radius:10px;border:1px solid var(--panel-border);background:linear-gradient(180deg,var(--panel-bg-start),var(--panel-bg-end));padding:8px;align-items:center;justify-content:center;gap:6px;cursor:pointer;box-shadow:inset 0 2px 10px rgba(0,0,0,.12)}.menu-btn span{display:block;width:100%;height:2px;background:var(--text);border-radius:2px;transition:transform .24s ease,opacity .2s ease,background .2s ease}.menu-btn:hover{filter:brightness(1.05)}nav.menu-open .menu-btn span:first-child{transform:translateY(8px) rotate(45deg)}nav.menu-open .menu-btn span:nth-child(2){opacity:0}nav.menu-open .menu-btn span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}.menu-panel{display:none}@media (max-width:720px){nav .links{display:none!important}.menu-btn{display:inline-flex}.menu-panel{display:none}nav.menu-open .menu-panel{display:grid;position:fixed;left:0;right:0;top:64px;padding:12px 16px 20px;background:color-mix(in oklab,var(--bg) 88%,#000 12%);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--panel-border);grid-gap:12px;gap:12px;animation:slideDown .22s ease}nav.menu-open .menu-panel a{color:var(--text);padding:10px 6px;border-radius:8px}nav.menu-open .menu-panel a:active{background:linear-gradient(180deg,var(--panel-bg-start),var(--panel-bg-end))}}@keyframes slideDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.hero{position:relative;padding:72px 0 28px;overflow:hidden}@media (max-width:720px){.hero{padding:84px 0 18px}}.hero h1{font-size:clamp(30px,6vw,70px);line-height:.95;margin:0 0 16px;letter-spacing:-.02em}.hero .sub{color:var(--muted);font-size:clamp(16px,2.2vw,20px);max-width:60ch}.typewriter .caret{display:inline-block;width:5px;height:.85em;margin-left:10px;background:var(--text);vertical-align:baseline;transform:translateY(2px);border-radius:3px;box-shadow:0 0 6px rgba(34,211,238,.28)}.typewriter .caret.on{opacity:1}.typewriter .caret:not(.on){opacity:0}.tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}.tag{border:1px solid var(--panel-border);color:var(--text);padding:8px 12px;border-radius:999px;font-size:14px;letter-spacing:.02em;background:linear-gradient(180deg,var(--panel-bg-start),var(--panel-bg-end))}.cta-row{margin-top:28px;display:flex;gap:14px}.btn{position:relative;display:inline-flex;align-items:center;gap:10px;padding:12px 16px;border-radius:12px;border:1px solid var(--panel-border);color:var(--text);text-decoration:none;overflow:hidden;transition:transform .15s ease,background .2s ease}.btn,.btn:hover{background:linear-gradient(180deg,var(--panel-bg-start),var(--panel-bg-end))}.btn:hover{transform:translateY(-1px)}.btn .pulse{position:absolute;inset:-40%;background:radial-gradient(closest-side,rgba(34,211,238,.18),rgba(34,211,238,0));transform:scale(0);transition:transform .35s ease}.btn:hover .pulse{transform:scale(1)}.projects{background:radial-gradient(1200px 600px at 10% 10%,rgba(139,92,246,.06),transparent),radial-gradient(800px 400px at 90% 10%,rgba(34,211,238,.06),transparent)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:18px;gap:18px}.projects-grid .card{text-decoration:none;color:inherit}.skills-grid{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.skills-sec .skills-head{display:flex;align-items:center;gap:12px}.skills-sec .skills-head .bar{width:36px;height:3px;border-radius:99px;background:var(--accent-2);display:inline-block}.skills-sec h2{margin:0;font-size:28px;letter-spacing:-.01em}.skill-chip{display:inline-flex;align-items:center;gap:8px;padding:10px 12px;border-radius:999px;background:linear-gradient(180deg,var(--panel-bg-start),var(--panel-bg-end));border:1px solid var(--panel-border);transition:transform .15s ease,border-color .2s ease,box-shadow .2s ease,background .2s ease}.skill-chip .icon{width:20px;height:20px;display:grid;place-items:center;color:var(--muted)}.skill-chip .icon .ic-letter{display:inline-grid;place-items:center;width:20px;height:20px;border-radius:6px;background:hsla(0,0%,100%,.06);color:var(--text);font-size:11px;font-weight:700}.skill-chip .text{font-size:14px;font-weight:600;color:var(--text)}.skill-chip:hover{transform:translateY(-1px);border-color:rgba(139,92,246,.45);box-shadow:0 8px 26px rgba(139,92,246,.12)}.skill-chip.web .icon{color:#8b5cf6}.skill-chip.lang .icon{color:#60a5fa}.skill-chip.db .icon{color:#22d3ee}.skill-chip.cloud .icon{color:#f59e0b}.skill-chip.ml .icon{color:#eab308}.skill-icon{color:var(--accent-2);font-size:22px;line-height:1;transform:translateY(2px)}.skill-icon svg{width:28px;height:28px;color:var(--accent-2)}.skill-icon.react svg{color:#61dafb}.skill-icon.next svg{color:#000}[data-theme=dark] .skill-icon.next svg{color:#fff}.skill-icon.ts svg{color:#3178c6}.skill-icon.tailwind svg{color:#38bdf8}.skill-icon.node svg{color:#3c873a}.skill-icon.db svg{color:#336791}.skill-icon.java svg{color:#f89820}.skill-icon.cloud svg{color:#f90}.skill-icon.lightning svg{color:#111}.skill-label{color:var(--text);font-weight:700;font-size:16px}.education-head,.experience-head,.projects-head{display:flex;align-items:center;gap:12px}.projects-head .bar{background:var(--accent)}.experience-head .bar,.projects-head .bar{width:36px;height:3px;border-radius:99px;display:inline-block}.experience-head .bar{background:#f59e0b}.education-head .bar{width:36px;height:3px;border-radius:99px;background:var(--accent);display:inline-block}.education-head h2,.experience-head h2,.projects-head h2{margin:0;font-size:28px;letter-spacing:-.01em}.card{position:relative;background:linear-gradient(180deg,var(--panel-bg-start),var(--panel-bg-end));border:1px solid var(--panel-border);border-radius:16px;padding:18px;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;will-change:transform;--c1:rgba(139,92,246,.55);--c2:rgba(34,211,238,.5)}.projects-grid .card:nth-child(3n+2){--c1:rgba(245,158,11,.55);--c2:rgba(139,92,246,.5)}.projects-grid .card:nth-child(3n){--c1:rgba(34,211,238,.55);--c2:rgba(245,158,11,.5)}.card:hover{border-color:color-mix(in oklab,var(--c1) 60%,#fff 40%);box-shadow:0 10px 40px color-mix(in oklab,var(--c1) 35%,#000 65%)}.card:after{content:"";position:absolute;inset:-1px;border-radius:24px;pointer-events:none;z-index:0;background:radial-gradient(120% 100% at 0 0,var(--c1),transparent 64%),radial-gradient(120% 100% at 100% 100%,var(--c2),transparent 64%);opacity:.3;filter:blur(28px);transition:opacity .25s ease,filter .25s ease}.card:hover:after{opacity:.46;filter:blur(38px)}@keyframes card-sweep{0%{transform:translateX(-120%)}to{transform:translateX(120%)}}.card:before{content:"";position:absolute;left:0;right:0;top:0;height:3px;pointer-events:none;z-index:1;background:linear-gradient(90deg,transparent,color-mix(in oklab,var(--c2) 60%,#fff 20%),transparent);opacity:0;transform:translateX(-120%)}.card:hover:before{opacity:.9;animation:card-sweep 1.8s ease-out 1}.card h3{margin:0 0 8px;font-size:18px}.card p{margin:0;color:var(--muted);font-size:14px;white-space:pre-line}.card-head{display:flex;align-items:center;gap:12px;margin-bottom:8px;position:relative;z-index:2}.card-head h3{margin:0}.picon{width:22px;height:22px;flex:0 0 22px;display:inline-flex;align-items:center;justify-content:center;font-size:18px;line-height:1;transform:translateY(-1px);filter:saturate(1.2);position:relative}.picon:after{z-index:-2;width:40px;height:40px;background:radial-gradient(60% 60% at 35% 35%,color-mix(in oklab,var(--c1) 75%,#fff 0),transparent 70%),radial-gradient(60% 60% at 70% 70%,color-mix(in oklab,var(--c2) 75%,#fff 0),transparent 70%);opacity:.42;filter:blur(10px);transition:transform .25s ease,opacity .25s ease,filter .25s ease}.picon:after,.picon:before{content:"";position:absolute;border-radius:999px}.picon:before{z-index:-1;width:34px;height:34px;background:radial-gradient(closest-side,transparent calc(100% - 4px),color-mix(in oklab,var(--c1) 70%,#fff 10%) 100%);opacity:.52;filter:blur(.2px);transition:transform .25s ease,opacity .25s ease}.card:hover .picon:after{opacity:.62;filter:blur(12px);transform:scale(1.08)}.card:hover .picon:before{transform:scale(1.05);opacity:.72}.picon .emoji{position:relative;z-index:1}@keyframes note-float{0%{transform:translate(-2px,6px) rotate(0deg);opacity:0}25%{opacity:.95}to{transform:translate(-10px,-20px) rotate(-8deg);opacity:0}}@keyframes note-float-b{0%{transform:translate(2px,8px) rotate(0deg);opacity:0}25%{opacity:.95}to{transform:translate(10px,-24px) rotate(10deg);opacity:0}}.picon.music .spark{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);pointer-events:none;font-size:12px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.4));z-index:3}.picon.music .spark.n1{animation:note-float 1.8s ease-in-out infinite;animation-delay:.1s}.picon.music .spark.n2{animation:note-float-b 2.2s ease-in-out infinite;animation-delay:.5s}.picon.clockfloat .spark{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);pointer-events:none;font-size:12px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.4));z-index:3}.picon.clockfloat .spark.n1{animation:note-float 1.8s ease-in-out infinite;animation-delay:.15s}.picon.clockfloat .spark.n2{animation:note-float-b 2.2s ease-in-out infinite;animation-delay:.55s}@keyframes compass-sway{0%{transform:rotate(-6deg)}50%{transform:rotate(6deg)}to{transform:rotate(-6deg)}}.picon.compass .emoji{display:inline-block;transform-origin:50% 90%;animation:compass-sway 1.2s ease-in-out infinite}@keyframes pin-trip{0%{transform:translate(-50%,-50%) translate(-4px,-3px) scale(1)}16%{transform:translate(-50%,-50%) translate(-4px,-6px) scale(1.02)}33%{transform:translate(-50%,-50%) translate(4px,-3px) scale(1)}49%{transform:translate(-50%,-50%) translate(4px,-5px) scale(1.02)}66%{transform:translate(-50%,-50%) translateY(3px) scale(1)}82%{transform:translate(-50%,-50%) translateY(2px) scale(.99)}to{transform:translate(-50%,-50%) translate(-4px,-3px) scale(1)}}.picon.pintrip .pin{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);font-size:14px;z-index:2;pointer-events:none;filter:drop-shadow(0 1px 2px rgba(0,0,0,.5));animation:pin-trip 2.6s ease-in-out infinite}@keyframes file-fly{0%{transform:translate(-20px,-12px) scale(1);opacity:1}55%{transform:translate(0) scale(.55);opacity:.15}to{transform:translate(0) scale(.5);opacity:0}}.picon .key-emoji.small{position:absolute;left:60%;top:32%;transform:translate(-50%,-50%) rotate(-12deg);font-size:11px;opacity:.9;filter:drop-shadow(0 1px 2px rgba(0,0,0,.45))}.picon .fly{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);font-size:14px;pointer-events:none;z-index:2;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5));animation:file-fly 2.6s ease-in-out infinite}@keyframes lock-flash{0%{transform:translate(-50%,-50%) scale(.4);opacity:0}35%{opacity:0}45%{transform:translate(-50%,-50%) scale(1.1);opacity:.95}60%{transform:translate(-50%,-50%) scale(.9);opacity:0}to{opacity:0}}.picon.filefly .flash{position:absolute;left:50%;top:50%;width:30px;height:30px;transform:translate(-50%,-50%);border-radius:999px;pointer-events:none;z-index:1;background:radial-gradient(closest-side,color-mix(in oklab,var(--c2) 75%,#fff 10%),transparent 70%);filter:blur(8px);opacity:0;animation:lock-flash 2.6s ease-out infinite}@keyframes loop-spin{to{transform:translate(-50%,-50%) rotate(1turn)}}@keyframes bot-pulse{0%{transform:translate(-50%,-50%) scale(.95)}50%{transform:translate(-50%,-50%) scale(1)}to{transform:translate(-50%,-50%) scale(.95)}}.picon.planner .bot{position:absolute;left:50%;top:50%;width:6px;height:6px;border-radius:999px;background:color-mix(in oklab,var(--c2) 82%,#fff 8%);box-shadow:0 0 8px color-mix(in oklab,var(--c2) 55%,#000 45%);z-index:2;animation:bot-pulse 1.8s ease-in-out infinite}.picon.planner .heading{width:0;height:0;border-left:5px solid color-mix(in oklab,var(--c1) 88%,#fff 8%);border-top:3px solid transparent;border-bottom:3px solid transparent;filter:drop-shadow(0 1px 2px rgba(0,0,0,.45));z-index:2}.picon.planner .heading,.picon.planner .loop{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);animation:loop-spin 1.6s linear infinite}.picon.planner .loop{width:24px;height:24px;border-radius:999px;background:conic-gradient(from 0deg,color-mix(in oklab,var(--c2) 85%,transparent) 0 28%,transparent 28% 100%);border:1px solid color-mix(in oklab,var(--c1) 30%,transparent);opacity:.75;filter:saturate(1.1) drop-shadow(0 0 6px color-mix(in oklab,var(--c2) 45%,black 55%))}@keyframes morph-on{0%{opacity:0;transform:translate(-50%,-50%) translateY(6px) scale(.9) rotate(-6deg)}8%{opacity:1;transform:translate(-50%,-50%) translateY(0) scale(1) rotate(0deg)}22%{opacity:1;transform:translate(-50%,-50%) translateY(0) scale(1) rotate(0deg)}30%{opacity:0;transform:translate(-50%,-50%) translateY(-8px) scale(.96) rotate(6deg)}to{opacity:0}}.picon.morph .emoji{opacity:0}.picon.morph .m{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);pointer-events:none;font-size:14px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.45))}.picon.morph .m.e1{animation:morph-on 3.2s ease-in-out 0s infinite}.picon.morph .m.e2{animation:morph-on 3.2s ease-in-out .8s infinite}.picon.morph .m.e3{animation:morph-on 3.2s ease-in-out 1.6s infinite}.picon.morph .m.e4{animation:morph-on 3.2s ease-in-out 2.4s infinite}.picon.clout{position:relative}.picon.clout .halo{position:absolute;inset:-2px;border-radius:999px;z-index:-1;background:radial-gradient(closest-side,color-mix(in oklab,var(--c1) 55%,#fff 0) 0,transparent 70%);filter:blur(8px);opacity:0;transform:scale(.9);animation:cloutHalo 2.6s ease-in-out infinite}.picon.clout .spark{position:absolute;pointer-events:none;filter:drop-shadow(0 1px 2px rgba(0,0,0,.35));opacity:0;transform:translate(-50%,-50%) scale(.6) rotate(0deg);animation:cloutPop 2.4s ease-in-out infinite;will-change:transform,opacity}.picon.clout .spark.s1{left:84%;top:20%;font-size:12px;animation-delay:.05s}.picon.clout .spark.s2{left:18%;top:28%;font-size:10px;animation-delay:.35s}.picon.clout .spark.s3{left:78%;top:78%;font-size:14px;animation-delay:.75s}@keyframes cloutHalo{0%{opacity:0;transform:scale(.9)}30%{opacity:.38;transform:scale(1.06)}60%{opacity:.18;transform:scale(1)}to{opacity:0;transform:scale(.95)}}@keyframes cloutPop{0%{opacity:0;transform:translate(-50%,-50%) scale(.6) rotate(-8deg)}12%{opacity:1;transform:translate(-50%,-56%) scale(1.05) rotate(0deg)}24%{opacity:1;transform:translate(-50%,-52%) scale(1) rotate(8deg)}40%{opacity:0;transform:translate(-50%,-46%) scale(.85) rotate(12deg)}to{opacity:0}}.picon.clout .emoji{display:inline-block;transform-origin:50% 60%;animation:cloutTrophy 3.2s ease-in-out .2s infinite}@keyframes cloutTrophy{0%,to{filter:brightness(1);transform:translateY(0) rotate(0deg)}40%{filter:brightness(1.06);transform:translateY(-1px) rotate(-1deg)}}@media (prefers-reduced-motion:reduce){.picon.clout .emoji,.picon.clout .halo,.picon.clout .spark{animation:none!important;opacity:1;transform:none}}.card .ext-link{position:absolute;top:8px;right:8px;width:24px;height:24px;display:inline-grid;place-items:center;color:var(--text);text-decoration:none;opacity:.8;transition:transform .15s ease,opacity .15s ease;z-index:4}.card .ext-link:hover{transform:translateY(-1px) scale(1.05);opacity:1}.card .card-link{position:absolute;inset:0;border-radius:16px;z-index:3;text-decoration:none}.card .card-link:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(139,92,246,.35)}.badge{position:absolute;top:12px;right:12px;font-size:11px;color:#0b0b0c;background:#e5e7eb;border-radius:999px;padding:4px 8px}.about{background:linear-gradient(180deg,hsla(0,0%,100%,.02),hsla(0,0%,100%,0))}.about .cols{display:grid;grid-template-columns:1.2fr 1fr;grid-gap:28px;gap:28px}@media (max-width:900px){.about .cols{grid-template-columns:1fr}}.kpi{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:16px;gap:16px;margin-top:24px}.kpi .tile{background:linear-gradient(180deg,hsla(0,0%,100%,.06),hsla(0,0%,100%,.02));border:1px solid hsla(0,0%,100%,.08);border-radius:12px;padding:16px;text-align:center}.kpi .tile .num{font-size:24px;font-weight:700}.kpi .tile .lbl{color:var(--muted);font-size:12px}footer{border-top:1px solid var(--panel-border);padding:8px 0 88px;color:var(--muted)}.footer-cols{display:grid;grid-template-columns:1fr 1fr;grid-gap:24px;gap:24px;align-items:start;justify-content:center}@media (max-width:900px){.footer-cols{grid-template-columns:1fr}}.contact-info{align-self:flex-start;padding-left:24px;display:flex;flex-direction:column;gap:0;text-align:left;align-items:flex-start}.contact-info .lead{color:var(--muted);font-size:14px;text-align:left;margin-top:10px}.contact-info .email{display:inline-block;font-weight:600;color:var(--text);text-decoration:none;font-size:18px;margin-top:0}.contact-row{align-items:center;flex-wrap:wrap}.contact-info .socials,.contact-row{display:flex;gap:10px;margin-top:0}@media (max-width:900px){.contact-info{padding-left:0}}.contact-form .field{display:grid;grid-gap:6px;gap:6px;margin-bottom:10px}.contact-form label{font-size:14px;color:var(--muted)}.contact-form input,.contact-form textarea{width:100%;color:var(--text);background:var(--card);border:1px solid var(--panel-border);border-radius:14px;padding:12px 14px;outline:none;transition:border-color .2s ease,box-shadow .2s ease;font-size:16px}.contact-form textarea{resize:vertical}.contact-form input::placeholder,.contact-form textarea::placeholder{color:#7b7f87;font-size:15px}.contact-form input:focus,.contact-form textarea:focus{border-color:rgba(139,92,246,.6);box-shadow:0 0 0 3px rgba(139,92,246,.15)}.icon-btn{color:var(--text);text-decoration:none;transition:transform .15s ease,background .2s ease}.icon-btn:hover{transform:translateY(-1px);background:linear-gradient(180deg,hsla(0,0%,100%,.1),hsla(0,0%,100%,.02))}[data-theme=light] .icon-btn{border-color:rgba(0,0,0,.14)!important;background:linear-gradient(180deg,rgba(0,0,0,.04),rgba(0,0,0,.01))!important}.reveal{opacity:0;transform:translateY(10px);transition:opacity .5s ease,transform .5s ease}.reveal.in{opacity:1;transform:translateY(0)}.timeline{position:relative;margin-top:14px}.experience .timeline{margin-top:4px}.timeline:before{content:"";position:absolute;left:18px;top:0;bottom:0;width:2px;background:linear-gradient(var(--panel-border),hsla(0,0%,100%,0));filter:blur(.2px)}.tl-item{position:relative;padding-left:64px;margin:22px 0}.tl-dot{display:none}.tl-card{position:relative;background:linear-gradient(180deg,var(--panel-bg-start),var(--panel-bg-end));border:1px solid var(--panel-border);border-radius:16px;padding:18px;box-shadow:0 6px 30px rgba(0,0,0,.25)}.tl-card:before{content:"";position:absolute;left:-46px;top:22px;width:46px;height:3px;background:linear-gradient(90deg,rgba(139,92,246,.7),transparent);border-radius:3px}@media (min-width:980px){.timeline{display:grid;grid-template-columns:1fr 1fr;grid-column-gap:60px;column-gap:60px}.timeline:before{left:50%;transform:translateX(-1px)}.tl-item{padding-left:0}.tl-item:nth-child(odd){grid-column:1;padding-right:48px}.tl-item:nth-child(2n){grid-column:2;padding-left:48px}.tl-item:nth-child(odd) .tl-card:before{left:auto;right:-46px;width:46px;height:3px;background:linear-gradient(270deg,rgba(245,158,11,.5),transparent)}.tl-item:nth-child(2n) .tl-card:before{left:-46px;right:auto;width:46px;height:3px;background:linear-gradient(90deg,rgba(245,158,11,.5),transparent)}}.tl-card:hover{transform:translateY(-2px);border-color:rgba(245,158,11,.5);box-shadow:0 10px 40px rgba(245,158,11,.18)}.tl-title{height:16px;width:50%;border-radius:6px;background:hsla(0,0%,100%,.08)}.tl-sub{height:12px;width:30%;border-radius:6px;background:hsla(0,0%,100%,.06);margin-top:8px}.tl-lines{margin-top:10px;display:grid;grid-gap:8px;gap:8px}.tl-lines .line{height:10px;width:85%;border-radius:6px;background:hsla(0,0%,100%,.06)}[data-theme=light] .tl-lines .line,[data-theme=light] .tl-sub,[data-theme=light] .tl-title{background:rgba(0,0,0,.06)}.tl-company{font-weight:800;font-size:20px}.tl-role{font-size:15px;margin-top:6px;font-style:italic}.tl-meta,.tl-role{color:var(--muted)}.tl-meta{opacity:.65;font-size:14px;margin-top:2px}.tl-list{margin:12px 0 0;padding-left:20px}.tl-list li{color:var(--muted);margin:8px 0;font-size:15px;line-height:1.6}.tl-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.tl-titleblock{min-width:0}.tl-logo-inline{height:46px;width:auto;margin-top:-6px;opacity:1;filter:none;object-fit:contain;border-radius:6px;background:transparent}@media (min-width:980px){.tl-logo-inline{height:54px;margin-top:-8px;border-radius:8px}}.brand-portfolio{background:linear-gradient(90deg,var(--accent-2),var(--accent));-webkit-background-clip:text;background-clip:text;color:transparent}.education .edu-card{margin-top:14px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;grid-gap:12px;gap:12px;padding:16px;border-radius:14px;background:linear-gradient(180deg,var(--panel-bg-start),var(--panel-bg-end));border:1px solid var(--panel-border);box-shadow:0 6px 24px rgba(0,0,0,.22);max-width:720px}.education .edu-icon{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;font-size:18px;background:radial-gradient(closest-side,rgba(139,92,246,.18),rgba(34,211,238,.12))}.education .edu-school{font-weight:800;font-size:20px}.education .edu-degree{color:var(--muted);font-size:15px;margin-top:2px}.education .edu-meta{color:var(--muted);opacity:.7;font-size:14px}.education .edu-meta.right{justify-self:end}