*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0b1120;--bg-2: #0f172a;--bg-card: #1e293b;--bg-card-hover:#263247;--border: #1e3a5f;--border-soft: #334155;--text: #e2e8f0;--text-muted: #94a3b8;--text-dim: #64748b;--accent: #38bdf8;--accent-dim: rgba(56,189,248,.12);--accent-glow: rgba(56,189,248,.35);--purple: #818cf8;--teal: #2dd4bf;--radius: 14px;--radius-sm: 8px;--font: "Inter", system-ui, -apple-system, sans-serif;--section-gap: 7rem;--nav-scrolled-bg: rgba(11,17,32,.88);--mobile-menu-bg: rgba(11,17,32,.97)}[data-theme=light]{--bg: #f8fafc;--bg-2: #f1f5f9;--bg-card: #ffffff;--bg-card-hover:#f1f5f9;--border: #cbd5e1;--border-soft: #e2e8f0;--text: #0f172a;--text-muted: #475569;--text-dim: #94a3b8;--accent: #0284c7;--accent-dim: rgba(2,132,199,.1);--accent-glow: rgba(2,132,199,.25);--purple: #6366f1;--teal: #0d9488;--nav-scrolled-bg: rgba(248,250,252,.92);--mobile-menu-bg: rgba(248,250,252,.97)}html{scroll-behavior:smooth}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.6;font-size:15px;-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}img{max-width:100%;display:block}.container{width:100%;max-width:1100px;margin:0 auto;padding:0 1.5rem}.app{min-height:100vh;display:flex;flex-direction:column}.reveal{opacity:0;transform:translateY(32px);transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1)}.reveal.visible{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.3s}@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}.section{padding:var(--section-gap) 0;position:relative}.section-header{text-align:center;margin-bottom:3.5rem}.section-eyebrow{display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);background:var(--accent-dim);border:1px solid rgba(56,189,248,.25);padding:.3rem .85rem;border-radius:999px;margin-bottom:.85rem}.section-title{font-size:clamp(1.8rem,4vw,2.6rem);font-weight:900;letter-spacing:-.04em;background:linear-gradient(135deg,var(--text) 30%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.1;margin-bottom:.75rem}.section-subtitle{color:var(--text-muted);font-size:.95rem;max-width:800px;margin:0 auto;line-height:1.7}.navbar{position:fixed;top:0;left:0;right:0;z-index:900;transition:background .3s,box-shadow .3s,backdrop-filter .3s;padding:1rem 0}.navbar--scrolled{background:var(--nav-scrolled-bg);-webkit-backdrop-filter:blur(16px) saturate(1.6);backdrop-filter:blur(16px) saturate(1.6);box-shadow:0 1px 0 var(--border);padding:.6rem 0}.navbar-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem}.navbar-logo{display:flex;align-items:center;gap:.45rem;font-size:1.1rem;font-weight:800;letter-spacing:-.03em;color:var(--text);text-decoration:none!important}.navbar-logo:hover{color:var(--accent)}.navbar-logo-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent-glow)}.navbar-logo-accent{color:var(--accent)}.navbar-links{display:flex;align-items:center;gap:.15rem;list-style:none}.navbar-links a{display:block;padding:.4rem .85rem;border-radius:999px;font-size:.84rem;font-weight:500;color:var(--text-muted);text-decoration:none!important;transition:color .2s,background .2s}.navbar-links a:hover{color:var(--text);background:#ffffff0d}.navbar-links a.active{color:var(--accent);background:var(--accent-dim)}.navbar-burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.3rem}.navbar-burger span{display:block;width:22px;height:2px;background:var(--text-muted);border-radius:2px;transition:transform .25s,opacity .25s}.theme-toggle{width:36px;height:36px;border-radius:50%;border:1px solid var(--border-soft);background:var(--bg-card);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .25s ease;flex-shrink:0}.theme-toggle:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim);transform:rotate(15deg) scale(1.08)}.theme-toggle svg{width:18px;height:18px;transition:transform .35s ease}.theme-toggle:active svg{transform:rotate(360deg)}.navbar-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.navbar-burger.open span:nth-child(2){opacity:0}.navbar-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.hero-section{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:7rem 0 5rem;position:relative;overflow:hidden}.hero-blob{position:absolute;border-radius:50%;filter:blur(90px);pointer-events:none;opacity:.45}.hero-blob--1{width:600px;height:600px;background:radial-gradient(circle,rgba(56,189,248,.18) 0%,transparent 70%);top:-150px;left:-200px}.hero-blob--2{width:500px;height:500px;background:radial-gradient(circle,rgba(129,140,248,.14) 0%,transparent 70%);bottom:-100px;right:-150px}.hero-blob--3{width:300px;height:300px;background:radial-gradient(circle,rgba(45,212,191,.1) 0%,transparent 70%);top:40%;left:55%}[data-theme=light] .hero-blob{opacity:.25}.hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr auto;gap:4rem;align-items:center}.hero-content{max-width:640px}.hero-eyebrow{display:inline-block;font-size:.9rem;color:var(--text-muted);margin-bottom:1rem;letter-spacing:.02em}.hero-name{font-size:clamp(2.2rem,6vw,4rem);font-weight:900;letter-spacing:-.04em;line-height:1.25;background:linear-gradient(120deg,var(--text) 20%,var(--accent) 60%,var(--purple) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.6rem}.hero-title-badge{display:inline-block;font-size:.85rem;font-weight:600;color:var(--accent);background:var(--accent-dim);border:1px solid rgba(56,189,248,.3);padding:.3rem 1rem;border-radius:999px;margin-bottom:1.5rem;letter-spacing:.04em}.hero-bio{color:var(--text-muted);font-size:.9rem;line-height:1.8;margin-bottom:2rem}.hero-cta{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.75rem}.btn-primary{display:inline-flex;align-items:center;gap:.45rem;padding:.7rem 1.5rem;background:var(--accent);color:#0b1120;font-size:.88rem;font-weight:700;border:none;border-radius:999px;cursor:pointer;transition:transform .2s,box-shadow .2s;text-decoration:none;font-family:var(--font)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 24px var(--accent-glow)}.btn-outline{display:inline-flex;align-items:center;gap:.45rem;padding:.7rem 1.5rem;background:transparent;color:var(--text-muted);font-size:.88rem;font-weight:600;border:1px solid var(--border-soft);border-radius:999px;cursor:pointer;transition:all .2s;font-family:var(--font);text-decoration:none}.btn-outline:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.hero-socials{display:flex;gap:.5rem}.social-icon-btn{width:38px;height:38px;border-radius:50%;background:var(--bg-card);border:1px solid var(--border-soft);display:flex;align-items:center;justify-content:center;color:var(--text-muted);text-decoration:none!important;transition:all .2s}.social-icon-btn svg{width:16px;height:16px;flex-shrink:0}.social-icon-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim);transform:translateY(-2px)}.hero-avatar-wrap{position:relative;flex-shrink:0}.hero-avatar-ring{position:relative;width:260px;height:260px;border-radius:28px;background:linear-gradient(135deg,#38bdf840,#818cf840);padding:4px;box-shadow:0 0 0 1px #38bdf833,0 20px 60px #00000080}[data-theme=light] .hero-avatar-ring{box-shadow:0 0 0 1px #0284c726,0 20px 60px #0000001f}.hero-avatar{width:100%;height:100%;object-fit:cover;object-position:center 0;border-radius:24px;display:block}.hero-avatar-fallback.avatar-fallback{width:100%;height:100%;border-radius:24px;background:linear-gradient(135deg,#38bdf8,#818cf8);display:flex;align-items:center;justify-content:center;font-size:3.5rem;font-weight:800;color:#0b1120}.hero-badge{position:absolute;background:var(--bg-card);border:1px solid var(--border-soft);border-radius:12px;padding:.5rem .9rem;display:flex;flex-direction:column;align-items:center;box-shadow:0 8px 24px #0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:float 4s ease-in-out infinite}.hero-badge--exp{top:-18px;right:-24px;animation-delay:0s}.hero-badge--stack{bottom:-14px;left:-28px;animation-delay:-2s}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.hero-badge-num{font-size:1.1rem;font-weight:800;color:var(--accent);line-height:1}.hero-badge-label{font-size:.65rem;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em;white-space:nowrap}.hero-scroll-hint{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:.4rem;font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);cursor:pointer;z-index:1;transition:color .2s}.hero-scroll-hint:hover{color:var(--accent)}.hero-scroll-hint svg{animation:bounce 1.8s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(4px)}}.skills-section{background:linear-gradient(180deg,var(--bg-2) 0%,var(--bg) 100%)}.tech-skills-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem 3rem;background:var(--bg-card);border:1px solid var(--border-soft);border-radius:var(--radius);padding:2rem 2.5rem}.tech-skill-item{display:block}.tech-skill-label{font-size:.88rem;font-weight:700;color:var(--text);white-space:nowrap}.tech-skill-value{font-size:.88rem;color:var(--text-muted)}.tech-skill-list{padding-left:1.25rem;margin:0;list-style:disc}.tech-skill-list li{font-size:.85rem;color:var(--text-muted);line-height:1.7}.projects-section{background:var(--bg)}.filter-pills{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:2.5rem}.filter-pill{padding:.4rem 1.1rem;border-radius:999px;border:1px solid var(--border-soft);background:var(--bg-card);color:var(--text-muted);font-size:.8rem;font-weight:500;cursor:pointer;font-family:var(--font);transition:all .2s}.filter-pill:hover{border-color:var(--accent);color:var(--accent)}.filter-pill.active{background:var(--accent);border-color:var(--accent);color:#0b1120;font-weight:700}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem}.project-card{background:var(--bg-card);border:1px solid var(--border-soft);border-radius:var(--radius);padding:0;cursor:pointer;display:flex;flex-direction:column;transition:all .22s ease;position:relative;overflow:hidden}.project-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 60%,rgba(56,189,248,.03));pointer-events:none;z-index:1}.project-card:hover{border-color:#38bdf866;background:var(--bg-card-hover);box-shadow:0 8px 32px #00000059;transform:translateY(-4px)}.project-card-thumb{position:relative;width:100%;height:180px;overflow:hidden;flex-shrink:0}.project-card-thumb-img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease,opacity .35s ease}.project-card:hover .project-card-thumb-img{transform:scale(1.06);opacity:.85}.project-card-thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a2236,#1e293b);color:var(--text-dim)}.project-card-thumb-placeholder--video{background:linear-gradient(135deg,#1a1a2e,#16213e);color:var(--accent)}.project-card-thumb-badge{position:absolute;top:.6rem;left:.6rem;z-index:2;background:var(--bg-card);border-radius:999px;padding:.1rem}.project-card-thumb-media{position:absolute;bottom:.5rem;right:.5rem;z-index:2;display:flex;gap:.35rem}.project-card-media-count{display:inline-flex;align-items:center;gap:.25rem;font-size:.68rem;font-weight:600;color:#fff;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:.2rem .5rem;border-radius:999px}.project-card-title,.project-card-summary,.project-card-tags,.project-card-footer{padding-left:1.4rem;padding-right:1.4rem}.project-card-title{font-size:.98rem;font-weight:700;color:var(--text);line-height:1.35;padding-top:1rem;margin-bottom:.35rem}.project-card-summary{font-size:.83rem;color:var(--text-muted);line-height:1.65;flex:1;margin-bottom:.35rem}.project-card-tags{display:flex;flex-wrap:wrap;gap:.3rem;margin-bottom:.35rem}.project-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:.3rem;padding-top:.8rem;padding-bottom:1.2rem;border-top:1px solid var(--border-soft)}.project-card-date{font-size:.74rem;color:var(--text-dim)}.project-card-cta{display:inline-flex;align-items:center;gap:.3rem;font-size:.78rem;font-weight:600;color:var(--accent);opacity:.6;transition:opacity .2s}.project-card:hover .project-card-cta{opacity:1}.tag{font-size:.7rem;padding:.18rem .58rem;border-radius:999px;background:var(--accent-dim);color:var(--accent);border:1px solid rgba(56,189,248,.2);font-weight:500}.tag--more{background:#64748b26;color:var(--text-dim);border-color:#64748b33}.badge{font-size:.68rem;font-weight:700;padding:.18rem .65rem;border-radius:999px;border:1px solid;display:inline-flex;align-items:center;white-space:nowrap}.badge--purple{background:#818cf81f;color:#a5b4fc;border-color:#818cf840}.badge--teal{background:#2dd4bf1a;color:#5eead4;border-color:#2dd4bf38}.badge--gray{background:#64748b1f;color:#94a3b8;border-color:#64748b33}.experience-section{background:linear-gradient(180deg,var(--bg) 0%,var(--bg-2) 100%)}.tl{position:relative;padding-left:3rem;max-width:780px;margin:0 auto}.tl:before{content:"";position:absolute;left:10px;top:0;bottom:0;width:2px;background:linear-gradient(180deg,var(--accent) 0%,var(--border-soft) 30%,var(--border-soft) 70%,transparent 100%)}.tl-year-group{position:relative}.tl-year-marker{position:relative;display:flex;align-items:center;margin-bottom:1.25rem;margin-top:.5rem}.tl-year-group:first-child .tl-year-marker{margin-top:0}.tl-year-label{position:absolute;left:-3rem;width:3.5rem;text-align:center;font-size:.78rem;font-weight:800;letter-spacing:.06em;color:#0b1120;background:var(--accent);padding:.25rem .5rem;border-radius:999px;box-shadow:0 0 12px var(--accent-glow),0 2px 8px #0006;z-index:2}.tl-entry{position:relative;padding-bottom:1.5rem}.tl-entry:last-child{padding-bottom:0}.tl-dot-wrap{position:absolute;left:-3rem;top:1.25rem;width:22px;display:flex;justify-content:center;z-index:2}.tl-dot{width:12px;height:12px;border-radius:50%;border:2px solid var(--bg-2);box-shadow:0 0 0 2px var(--border-soft);transition:all .25s}.tl-dot--work{background:var(--accent);box-shadow:0 0 0 2px #38bdf84d}.tl-dot--edu{background:#818cf8;box-shadow:0 0 0 2px #818cf84d}.tl-entry:hover .tl-dot{transform:scale(1.35)}.tl-entry--highlight .tl-dot{box-shadow:0 0 0 3px var(--accent-glow)}.tl-card{background:var(--bg-card);border:1px solid var(--border-soft);border-radius:var(--radius);padding:1.2rem 1.4rem;cursor:pointer;transition:all .22s ease;display:flex;flex-direction:column;gap:.4rem;position:relative}.tl-card:hover{border-color:#38bdf866;background:var(--bg-card-hover);box-shadow:0 6px 28px #00000059;transform:translate(6px)}.tl-card--current{border-left:3px solid var(--accent)}.tl-entry--edu .tl-card:hover{border-color:#818cf866}.tl-current-badge{position:absolute;top:-10px;right:12px;font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:var(--accent);color:#0b1120;padding:.2rem .65rem;border-radius:999px}.tl-card-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;flex-wrap:wrap}.tl-card-type{display:inline-flex;align-items:center;gap:.3rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.tl-card-type--work{color:var(--accent)}.tl-card-type--edu{color:#818cf8}.tl-card-period{font-size:.74rem;color:var(--text-dim);font-weight:500}.tl-card-title{font-size:.95rem;font-weight:700;color:var(--text);line-height:1.3}.tl-card-company{display:flex;align-items:center;gap:.3rem;font-size:.8rem;color:var(--text-muted)}.tl-card-summary{font-size:.82rem;color:var(--text-muted);line-height:1.65}.tl-card-images{display:flex;gap:.4rem;margin-top:.25rem}.tl-card-thumb{width:56px;height:40px;object-fit:cover;border-radius:6px;border:1px solid var(--border-soft);transition:transform .2s,opacity .2s}.tl-card-thumb:hover{transform:scale(1.08);opacity:.85}.tl-card-more-img{width:56px;height:40px;border-radius:6px;background:var(--bg);border:1px solid var(--border-soft);display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:600;color:var(--text-dim)}.tl-card-tags{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:.15rem}.tl-card-cta{display:inline-flex;align-items:center;gap:.3rem;font-size:.76rem;font-weight:600;color:var(--accent);opacity:0;transition:opacity .2s;margin-top:.2rem}.tl-card:hover .tl-card-cta{opacity:1}.tl-end{position:relative;padding-top:1.5rem}.tl-end-dot{position:absolute;left:-3rem;top:1.5rem;width:22px;display:flex;justify-content:center}.tl-end-dot:before{content:"";width:8px;height:8px;border-radius:50%;background:var(--border-soft)}.contact-section{position:relative;overflow:hidden}.contact-bg-gradient{position:absolute;inset:0;z-index:0;background:radial-gradient(ellipse 60% 50% at 50% 0%,rgba(56,189,248,.07) 0%,transparent 70%),radial-gradient(ellipse 40% 40% at 90% 100%,rgba(129,140,248,.06) 0%,transparent 70%);pointer-events:none}.contact-section .container{position:relative;z-index:1}.contact-layout{display:grid;grid-template-columns:1fr 380px;gap:2rem;align-items:start}.contact-info{display:flex;flex-direction:column;gap:.75rem}.contact-card{display:flex;align-items:center;gap:1rem;background:var(--bg-card);border:1px solid var(--border-soft);border-radius:var(--radius);padding:1rem 1.25rem;color:var(--text);text-decoration:none!important;transition:all .22s;cursor:pointer}.contact-card--static{cursor:default}.contact-card:not(.contact-card--static):hover{border-color:#38bdf866;background:var(--bg-card-hover);box-shadow:0 4px 16px #00000040;transform:translate(4px)}.contact-card-icon{width:44px;height:44px;border-radius:10px;background:var(--accent-dim);border:1px solid rgba(56,189,248,.2);display:flex;align-items:center;justify-content:center;color:var(--accent);flex-shrink:0}.contact-card div{flex:1;display:flex;flex-direction:column;gap:.15rem}.contact-card-label{font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim)}.contact-card-value{font-size:.88rem;color:var(--text-muted);font-weight:500}.contact-card-arrow{color:var(--text-dim);flex-shrink:0;transition:transform .2s,color .2s}.contact-card:not(.contact-card--static):hover .contact-card-arrow{color:var(--accent);transform:translate(3px)}.contact-social-panel{background:var(--bg-card);border:1px solid var(--border-soft);border-radius:var(--radius);padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.contact-social-heading{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--text-dim)}.contact-social-list{display:flex;flex-direction:column;gap:.5rem}.contact-social-item{display:flex;align-items:center;gap:.85rem;padding:.65rem .85rem;border-radius:var(--radius-sm);background:var(--bg);border:1px solid var(--border-soft);color:var(--text-muted);text-decoration:none!important;font-size:.84rem;font-weight:500;transition:all .2s}.contact-social-item:hover{border-color:#38bdf859;color:var(--text);background:var(--bg-card-hover)}.contact-social-icon{width:18px;height:18px;display:flex;align-items:center;color:var(--text-muted)}.contact-social-icon svg{width:100%;height:100%}.contact-social-name{flex:1}.contact-availability{display:flex;align-items:center;gap:.5rem;font-size:.77rem;color:var(--text-dim);font-weight:500;padding-top:.5rem;border-top:1px solid var(--border-soft)}.availability-dot{width:8px;height:8px;border-radius:50%;background:#4ade80;box-shadow:0 0 8px #4ade8080;flex-shrink:0;animation:pulse-green 2s ease-in-out infinite}@keyframes pulse-green{0%,to{box-shadow:0 0 6px #4ade8066}50%{box-shadow:0 0 14px #4ade80b3}}.modal-overlay{position:fixed;inset:0;background:#000000bf;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-box{background:var(--bg-card);border:1px solid var(--border-soft);border-radius:16px;padding:2rem;width:100%;max-width:640px;max-height:90vh;overflow-y:auto;position:relative;animation:slideUp .25s ease;scrollbar-width:thin;scrollbar-color:var(--border-soft) transparent}@keyframes slideUp{0%{opacity:0;transform:translateY(24px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-close{position:absolute;top:1rem;right:1rem;background:var(--bg);border:1px solid var(--border-soft);border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-muted);transition:all .2s}.modal-close:hover{background:var(--border-soft);color:var(--text)}.modal-date{font-size:.78rem;color:var(--text-dim);margin-bottom:.4rem}.modal-title{font-size:1.4rem;font-weight:800;color:var(--text);line-height:1.25;margin-bottom:.4rem}.modal-sub{font-size:.85rem;color:var(--text-muted);margin-bottom:1.25rem}.modal-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.75rem;margin-bottom:1.5rem}.modal-thumb-btn{background:none;border:none;padding:0;cursor:pointer;border-radius:8px;overflow:hidden;display:block}.modal-img{width:100%;height:130px;object-fit:cover;border-radius:8px;border:1px solid var(--border-soft);transition:transform .2s,opacity .2s;display:block}.modal-thumb-btn:hover .modal-img{transform:scale(1.04);opacity:.85}.modal-video-section{margin-bottom:1.5rem;display:flex;flex-direction:column;gap:.75rem}.modal-video{width:100%;max-height:400px;border-radius:10px;border:1px solid var(--border-soft);background:#000;display:block}.lightbox-overlay{position:fixed;inset:0;z-index:2000;background:#000000eb;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;animation:fadeIn .18s ease}.lightbox-img-wrap{display:flex;flex-direction:column;align-items:center;max-width:calc(100vw - 8rem);max-height:100vh}.lightbox-img{max-width:100%;max-height:calc(100vh - 5rem);object-fit:contain;border-radius:8px;box-shadow:0 8px 48px #0009;animation:slideUp .2s ease}.lightbox-counter{margin-top:.6rem;font-size:.78rem;color:#ffffff73;font-variant-numeric:tabular-nums}.lightbox-close{position:fixed;top:1.25rem;right:1.25rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:background .2s;z-index:1}.lightbox-close:hover{background:#fff3}.lightbox-nav{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:50%;width:44px;height:44px;flex-shrink:0;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:background .2s;margin:0 1rem}.lightbox-nav:hover{background:#ffffff38}.modal-content{margin-bottom:1.25rem}.modal-content h3{font-size:1rem;font-weight:700;color:var(--accent);margin:1.25rem 0 .5rem}.modal-content h4{font-size:.9rem;font-weight:600;color:var(--text);margin:1rem 0 .4rem}.modal-content p{font-size:.875rem;color:var(--text-muted);line-height:1.75;margin-bottom:.5rem}.modal-content strong{color:var(--text)}.modal-content a{color:var(--accent)}.modal-content ul{padding-left:1.25rem;margin:.5rem 0}.modal-content li{font-size:.875rem;color:var(--text-muted);line-height:1.75;margin-bottom:.25rem}.modal-content blockquote{border-left:3px solid var(--accent);padding:.5rem 1rem;background:#38bdf80f;border-radius:0 6px 6px 0;margin:.75rem 0;font-style:italic;color:var(--text-muted);font-size:.875rem}.modal-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:1.25rem}.modal-close-btn{width:100%;padding:.75rem;background:var(--bg);border:1px solid var(--border-soft);border-radius:8px;color:var(--text-muted);font-size:.875rem;font-weight:600;cursor:pointer;font-family:var(--font);transition:all .2s}.modal-close-btn:hover{background:var(--border-soft);color:var(--text)}.site-footer{border-top:1px solid var(--border-soft);padding:2rem 1.5rem;text-align:center}.site-footer p{font-size:.8rem;color:var(--text-dim)}.site-footer a{color:var(--text-muted)}.back-to-top{position:fixed;bottom:2rem;right:2rem;z-index:999;width:44px;height:44px;border-radius:50%;background:var(--accent);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 16px var(--accent-glow);transition:transform .2s,box-shadow .2s;animation:fadeIn .25s ease}[data-theme=light] .back-to-top{color:#fff}.back-to-top:hover{transform:translateY(-3px);box-shadow:0 6px 24px var(--accent-glow)}@media(max-width:900px){:root{--section-gap: 5rem}.hero-inner{grid-template-columns:1fr;text-align:center;gap:3rem}.hero-content{max-width:100%}.hero-cta,.hero-socials{justify-content:center}.hero-avatar-wrap{margin:0 auto}.hero-avatar-ring{width:200px;height:200px}.hero-badge--exp{top:-14px;right:0}.hero-badge--stack{bottom:-10px;left:-14px}.tl{padding-left:2.5rem}.contact-layout{grid-template-columns:1fr}}@media(max-width:700px){.navbar-links{position:fixed;top:0;left:0;right:0;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;height:100vh;background:var(--mobile-menu-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);transform:translateY(-110%);transition:transform .3s ease;z-index:800}.navbar-links.open{transform:translateY(0)}.navbar-links a{font-size:1.1rem;padding:.65rem 2rem}.navbar-burger{display:flex;z-index:910}.tech-skills-grid,.projects-grid{grid-template-columns:1fr}.hero-avatar-ring{width:160px;height:160px}}@media(max-width:480px){:root{--section-gap: 4rem}body{font-size:14px}.modal-box{padding:1.5rem 1.25rem;border-radius:12px}.modal-title{font-size:1.2rem}.modal-gallery{grid-template-columns:repeat(2,1fr)}.hero-badge{display:none}.hero-name{font-size:2.2rem}}
