@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=Space+Grotesk:wght@500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg-color:#f7f7f9;--card-bg:#fff;--text-main:#111;--text-muted:#666;--border-color:#e5e5e5;--accent:#2ecc71;--accent-hover:#27ae60;--link-color:#867eff;--radius:24px}[data-theme=dark]{--bg-color:#09090b;--card-bg:#18181b;--text-main:#f4f4f5;--text-muted:#a1a1aa;--border-color:#27272a}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-main);-webkit-font-smoothing:antialiased;font-family:Inter,sans-serif;line-height:1.5;transition:background-color .3s,color .3s}h1,h2,h3,h4{letter-spacing:-.04em;color:var(--text-main);font-family:Space Grotesk,sans-serif;font-weight:700}a{color:var(--link-color);text-decoration:none}.app-wrapper{max-width:1200px;margin:0 auto;padding:2rem 2rem 4rem}.bento-grid{grid-template-columns:repeat(12,1fr);grid-auto-flow:dense;gap:1.5rem;display:grid}.bento-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius);flex-direction:column;padding:2.5rem;transition:transform .2s,box-shadow .2s,background-color .3s,border-color .3s;display:flex;position:relative;overflow:hidden}.bento-card:hover{border-color:var(--text-muted);transform:translateY(-2px);box-shadow:0 12px 24px -10px #0000000d}@media (width>=1024px){.col-span-12{grid-column:span 12}.col-span-8{grid-column:span 8}.col-span-7{grid-column:span 7}.col-span-5{grid-column:span 5}.col-span-6{grid-column:span 6}.col-span-4{grid-column:span 4}}@media (width<=1023px) and (width>=768px){.col-span-12,.col-span-8,.col-span-7,.col-span-6,.col-span-5,.col-span-4{grid-column:span 6}.bento-card.hero-card{grid-column:span 12}}@media (width<=767px){.app-wrapper{padding:1.25rem 1rem 3rem}.bento-card{padding:1.5rem}.bento-grid{grid-template-columns:1fr;gap:1.25rem}.col-span-12,.col-span-8,.col-span-7,.col-span-6,.col-span-5,.col-span-4{grid-column:span 1;min-width:0}.hero-title{white-space:normal;overflow-wrap:anywhere;word-wrap:break-word}.hero-actions{flex-wrap:wrap;gap:.75rem;margin-top:.75rem}.hero-actions .btn{flex:calc(50% - .5rem);justify-content:center;min-width:min(100%,12rem)}}@media (width>=768px){.hero-title{white-space:nowrap}}.hero-actions{gap:1rem;margin-top:1rem;display:flex}.projects-grid{grid-template-columns:1fr;gap:1.5rem;min-width:0;display:grid}@media (width>=640px){.projects-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.projects-grid>*{min-width:0}.projects-grid h3{overflow-wrap:break-word}a.project-card-icon-link{color:var(--text-muted);justify-content:center;align-items:center;transition:color .2s;display:inline-flex}a.project-card-icon-link:hover{color:var(--accent)}.project-modal-footer-links a.btn-outline:hover{color:var(--accent);border-color:var(--accent);background:0 0}.project-modal-footer-links a.btn-primary:hover{background:var(--accent);border-color:var(--accent);color:#fff;opacity:1}.project-modal-panel{flex-direction:column;min-height:0;max-height:min(90dvh,900px);display:flex;overflow:hidden}.project-modal-header{border-bottom:1px solid var(--border-color);background:var(--card-bg);flex-shrink:0;justify-content:space-between;align-items:flex-start;gap:.75rem;padding:1rem clamp(1rem,4vw,2rem);display:flex}.project-modal-title{letter-spacing:-.03em;overflow-wrap:anywhere;word-break:break-word;min-width:0;color:var(--text-main);flex:1;margin:0;padding-top:.2rem;font-family:Space Grotesk,sans-serif;font-size:1.1rem;font-weight:700;line-height:1.35}.project-modal-close{box-sizing:border-box;aspect-ratio:1;border:1px solid var(--border-color);background:var(--bg-color);width:44px;min-width:44px;height:44px;min-height:44px;color:var(--text-muted);cursor:pointer;appearance:none;-webkit-tap-highlight-color:transparent;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin:0;padding:0;transition:color .2s,border-color .2s;display:inline-flex}.project-modal-close:hover{color:var(--text-main);border-color:var(--text-main)}.project-modal-body-scroll{-webkit-overflow-scrolling:touch;overscroll-behavior:contain;flex:auto;min-height:0;padding:clamp(1.25rem,4vw,2rem);overflow:hidden auto}.project-screenshots-grid img{min-width:0}.projects-see-more-wrap{justify-content:center;margin-top:1.75rem;padding-top:.25rem;display:flex}.projects-see-more-btn{letter-spacing:-.02em;cursor:pointer;color:var(--text-main);background:0 0;border:none;border-radius:0;justify-content:center;align-items:center;gap:.45rem;padding:.35rem 0;font-family:Space Grotesk,sans-serif;font-size:.9rem;font-weight:600;transition:color .2s;display:inline-flex}.projects-see-more-btn:hover{color:var(--accent)}.projects-see-more-btn:focus-visible{outline:2px solid var(--accent);outline-offset:4px}.projects-see-more-btn:hover .projects-see-more-arrow{transform:translate(4px)}.projects-see-more-btn .projects-see-more-arrow{flex-shrink:0;transition:transform .2s}.card-title{align-items:center;gap:.5rem;margin-bottom:1.5rem;font-size:1.25rem;display:flex}.card-title:before{content:"";background-color:var(--text-main);width:8px;height:8px;box-shadow:0 0 10px var(--text-main);opacity:.9;border-radius:50%;display:block}.card-title:after{content:"";background-image:linear-gradient(90deg, var(--text-main) 50%, transparent 50%);background-size:6px 100%;flex:1;height:1px;margin-left:.6rem;-webkit-mask-image:linear-gradient(90deg,#0000004d 0%,#0000 100%);mask-image:linear-gradient(90deg,#0000004d 0%,#0000 100%)}.badge{background:var(--bg-color);color:var(--text-main);border:1px solid var(--border-color);border-radius:99px;align-items:center;padding:.4rem .8rem;font-family:JetBrains Mono,monospace;font-size:.85rem;font-weight:500;display:inline-flex}.btn{cursor:pointer;border:1px solid #0000;border-radius:99px;justify-content:center;align-items:center;width:fit-content;padding:.8rem 1.5rem;font-size:1rem;font-weight:500;transition:all .2s;display:inline-flex}.btn-primary{background:var(--text-main);color:var(--bg-color)}.btn-primary:hover{opacity:.8}.btn-outline{color:var(--text-main);border:1px solid var(--border-color);background:0 0}.btn-outline:hover{background:var(--bg-color)}ul.points-list{flex-direction:column;gap:.8rem;list-style:none;display:flex}ul.points-list li{color:var(--text-muted);padding-left:1.5rem;font-size:.95rem;position:relative}ul.points-list li:before{content:"→";color:var(--text-main);font-family:JetBrains Mono,monospace;position:absolute;left:0}.marquee-container{-webkit-user-select:none;user-select:none;gap:1rem;margin-bottom:1rem;padding:.5rem 0;display:flex;overflow:hidden}.marquee-content{flex-shrink:0;gap:1rem;animation:40s linear infinite scroll-left;display:flex}.marquee-content.reverse{animation:40s linear infinite scroll-right}@keyframes scroll-left{0%{transform:translate(0)}to{transform:translate(-50%)}}@keyframes scroll-right{0%{transform:translate(-50%)}to{transform:translate(0)}}.marquee-container:hover .marquee-content{animation-play-state:paused}.testimonials-marquee-wrap .marquee-content{animation-duration:80s}.navbar{z-index:50;background:var(--card-bg);border:1px solid var(--border-color);border-radius:99px;justify-content:space-between;align-items:center;margin-bottom:2rem;padding:1rem 2rem;display:flex;position:sticky;top:1rem;box-shadow:0 4px 6px -1px #0000000d}.nav-links{gap:1.5rem;font-size:.95rem;font-weight:500;list-style:none;display:flex}.nav-links a{color:var(--text-muted);font-weight:500;transition:color .2s,font-weight .15s}.nav-links a:hover:not(.nav-link-active){color:var(--accent)}.nav-links a.nav-link-active{color:var(--accent);font-weight:700}.nav-links a.nav-link-active:hover{color:var(--accent-hover)}.hamburger-btn{color:var(--text-main);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;padding:.4rem;transition:background .2s;display:none}.hamburger-btn:hover{background:var(--bg-color)}.mobile-menu-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#00000080;justify-content:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.mobile-menu{background:var(--card-bg);border-left:1px solid var(--border-color);width:280px;height:100%;padding:2rem 1.5rem;animation:.3s slideIn}.mobile-nav-links{flex-direction:column;gap:.25rem;margin-top:1rem;list-style:none;display:flex}.mobile-nav-links li a{color:var(--text-muted);border-radius:12px;padding:.9rem 1rem;font-size:1.05rem;font-weight:500;text-decoration:none;transition:all .2s;display:block}.mobile-nav-links li a:hover:not(.nav-link-active){color:var(--accent);background:var(--bg-color)}.mobile-nav-links li a.nav-link-active{color:var(--accent);background:color-mix(in srgb, var(--accent) 12%, transparent);font-weight:700}.mobile-nav-links li a.nav-link-active:hover{color:var(--accent-hover);background:color-mix(in srgb, var(--accent) 18%, transparent)}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (width<=768px){.nav-desktop{display:none}.hamburger-btn{display:flex}.navbar{padding:.8rem 1.5rem}}.theme-toggle{color:var(--text-main);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:.5rem;transition:background .2s;display:flex}.theme-toggle:hover{background:var(--bg-color)}.skill-badge{cursor:default;transition:all .3s}.skill-badge:hover{transform:translateY(-2px)scale(1.05);background:var(--text-main)!important;color:var(--card-bg)!important;border-color:var(--text-main)!important}.cert-link{color:var(--text-muted);cursor:pointer;margin-bottom:.25rem;font-size:.9rem;text-decoration:none;transition:color .2s;display:block}.cert-link:hover{color:var(--text-main);text-decoration:underline}@keyframes section-nav-highlight-ring{0%{opacity:0;border-color:#0000}20%{opacity:1;border-color:color-mix(in srgb, var(--accent) 42%, var(--border-color))}50%{border-color:color-mix(in srgb, var(--accent) 32%, var(--border-color))}to{opacity:0;border-color:#0000}}.section-nav-highlight{border-radius:var(--radius);z-index:5;isolation:isolate;position:relative;overflow:visible!important}.section-nav-highlight:before{content:"";border-radius:calc(var(--radius) + 2px);pointer-events:none;z-index:100;box-sizing:border-box;border:2px solid #0000;animation:1.2s ease-in-out forwards section-nav-highlight-ring;position:absolute;inset:-2px}#feedback.bento-card,#feedback.bento-card:hover{box-shadow:none}
