:root{--nav-h:68px;--footer-h:64px;--dark:#111112;--light:#f4f4f4;--white:#ffffff;--split:50vw;--parallax:0px}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-poppins),"Poppins",system-ui,sans-serif;background:var(--white);color:var(--dark);overflow-x:hidden}main{padding-bottom:var(--footer-h)}.navbar{position:fixed;inset:0 0 auto 0;height:var(--nav-h);background:#000;z-index:999}.nav-inner{height:100%;max-width:1280px;margin:0 auto;padding:0 48px;display:flex;align-items:center}.nav-logo{flex-shrink:0;width:44px;height:44px;border:2px solid rgba(255,255,255,.8);border-radius:50%;display:grid;place-items:center;color:#fff;text-decoration:none;font-size:.78rem;font-weight:700;letter-spacing:.06em;transition:border-color .2s}.nav-logo:hover{border-color:#fff}.nav-links{list-style:none;display:flex;gap:36px;flex:1 1;justify-content:center}.nav-link{color:rgba(255,255,255,.75);text-decoration:none;font-size:.875rem;font-weight:400;letter-spacing:.01em;transition:color .2s}.nav-link:hover{color:#fff}.nav-social{flex-shrink:0;gap:20px}.nav-social,.social-link{display:flex;align-items:center}.social-link{color:rgba(255,255,255,.7);justify-content:center;transition:color .2s}.social-link:hover{color:#fff}.social-link svg{width:15px;height:15px;fill:currentColor}.hero{position:relative;margin-top:var(--nav-h);height:clamp(360px,46vw,480px);max-width:1280px;margin-left:auto;margin-right:auto;overflow:hidden;cursor:none;box-shadow:0 8px 28px rgba(0,0,0,.1)}.hero-panel{position:absolute;inset:0;overflow:hidden;will-change:clip-path}.panel-designer{background:#fff;-webkit-clip-path:inset(0 calc(100% - var(--split)) 0 0);clip-path:inset(0 calc(100% - var(--split)) 0 0)}.panel-coder{background:#fff;-webkit-clip-path:inset(0 0 0 var(--split));clip-path:inset(0 0 0 var(--split))}.hero-img{bottom:0;left:50%;transform:translateX(calc(-50% + var(--parallax, 0px)));height:92%;max-height:440px;width:auto;max-width:42%;object-fit:contain;object-position:bottom center;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none;display:block;will-change:transform}.hero-copy,.hero-img{position:absolute;pointer-events:none}.hero-copy{top:50%;transform:translateY(-50%);max-width:290px}.designer-copy{left:clamp(32px,7vw,110px);color:var(--dark);text-align:left}.coder-copy{right:clamp(32px,7vw,110px);color:var(--dark);text-align:right}.hero-copy h1{font-size:clamp(2.6rem,5.2vw,4.8rem);font-weight:800;line-height:1;letter-spacing:-.03em;margin-bottom:14px}.hero-copy p{font-size:.92rem;font-weight:300;line-height:1.7;max-width:230px;opacity:.78}.code-bg{position:absolute;right:40px;top:50%;transform:translateY(-20%);display:flex;flex-direction:column;gap:6px;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.code-bg span{display:block;font-family:Courier New,Courier,monospace;font-size:.78rem;color:rgba(100,100,100,.22);white-space:nowrap;letter-spacing:.02em}.hero-divider{top:0;left:0;width:1px;height:100%;transform:translateX(calc(var(--split) - .5px));background:linear-gradient(180deg,transparent 0,rgba(255,255,255,.5) 14%,rgba(255,255,255,.5) 86%,transparent);will-change:transform}.hero-divider,.scroll-cue{position:absolute;pointer-events:none;z-index:20}.scroll-cue{bottom:28px;left:50%;transform:translateX(-50%);color:rgba(160,160,160,.7);animation:bounce 2.4s ease-in-out infinite;width:40px;height:40px;border:1.5px solid rgba(160,160,160,.38);border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.06)}@keyframes bounce{0%,to{transform:translateX(-50%) translateY(0);opacity:.55}50%{transform:translateX(-50%) translateY(5px);opacity:1}}.cursor-dot{position:fixed;top:0;left:0;width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.85);pointer-events:none;z-index:9999;transition:background .15s;will-change:transform}.cursor-dot.on-light{background:rgba(30,30,30,.55)}.work-section{background:#ebebeb;padding:72px 0 96px}.work-inner{max-width:1060px;margin:0 auto;padding:0 40px}.work-heading{text-align:center;font-size:.68rem;font-weight:600;letter-spacing:.22em;color:#999;margin-bottom:52px;display:flex;align-items:center;gap:20px}.work-heading:after,.work-heading:before{content:"";flex:1 1;height:1px;background:#d8d8d8}.work-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:24px;gap:24px}.work-card{background:var(--white);border-radius:10px;overflow:hidden;box-shadow:0 2px 16px rgba(0,0,0,.07);cursor:pointer;transition:transform .32s ease,box-shadow .32s ease}.work-card:hover{transform:translateY(-7px);box-shadow:0 14px 36px rgba(0,0,0,.13)}.card-thumb{height:196px;overflow:hidden}.thumb-ds{background:#f9fafb;padding:18px 18px 14px;display:flex;flex-direction:column;justify-content:center;gap:10px}.ds-badges{display:flex;gap:5px}.ds-badges span{font-size:.58rem;font-weight:600;padding:3px 8px;border-radius:20px;display:inline-flex;align-items:center;gap:3px}.badge-approved{background:#ecfdf5;color:#059669;border:1px solid #a7f3d0}.badge-pending{background:#fffbeb;color:#d97706;border:1px solid #fde68a}.badge-rejected{background:#fef2f2;color:#dc2626;border:1px solid #fca5a5}.ds-toast{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:9px 10px;display:flex;align-items:flex-start;gap:8px;box-shadow:0 1px 4px rgba(0,0,0,.05)}.ds-toast-check{width:16px;height:16px;background:#059669;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.52rem;flex-shrink:0;margin-top:1px}.ds-toast-body{flex:1 1;display:flex;flex-direction:column;gap:2px}.ds-toast-body strong{font-size:.64rem;font-weight:600;color:#111;display:block}.ds-toast-body span{font-size:.57rem;color:#9ca3af;display:block}.ds-toast-close{font-size:.82rem;color:#9ca3af;line-height:1}.ds-controls{display:flex;align-items:center;gap:10px}.ds-controls span{font-size:.6rem;color:#555;white-space:nowrap}.ctrl-check{color:#2563eb}.ctrl-tag{background:#f3f4f6;border:1px solid #e5e7eb;padding:2px 9px;border-radius:20px;font-size:.58rem!important;color:#555!important}.thumb-book{background:linear-gradient(150deg,#1e3a8a,#3b82f6 80%,#60a5fa);display:flex;align-items:center;justify-content:center;overflow:visible;position:relative}.book-stack{position:relative;width:100px;height:136px}.book-shadow{background:rgba(0,0,0,.25);border-radius:2px 6px 6px 2px;transform:translate(8px,6px);filter:blur(6px)}.book-pages,.book-shadow{position:absolute;inset:0}.book-pages{background:#f1f5f9;border-radius:1px 4px 4px 1px;transform:translate(7px,2px)}.book-cover{position:absolute;inset:0;background:linear-gradient(135deg,#1e40af,#2563eb 60%,#3b82f6);border-radius:2px 6px 6px 2px;display:flex;flex-direction:column;justify-content:center;padding:12px;box-shadow:4px 4px 16px rgba(0,0,0,.35)}.book-title{color:#fff;font-size:.96rem;font-weight:700;line-height:1.25;display:block}.book-stripe{display:block;width:28px;height:3px;background:rgba(255,255,255,.35);border-radius:2px;margin-top:10px}.thumb-app{background:#f0f2f5;display:flex;align-items:center;justify-content:center;padding:16px}.app-card-mock{background:#fff;border-radius:10px;box-shadow:0 2px 14px rgba(0,0,0,.1);padding:12px 14px;width:100%;max-width:248px}.app-card-header{display:flex;align-items:flex-start;gap:8px;margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid #f1f1f1}.app-icon{font-size:1rem;line-height:1;flex-shrink:0}.app-match{font-size:.68rem;font-weight:600;color:#111;line-height:1.3}.app-meta{font-size:.57rem;color:#9ca3af;margin-top:2px}.app-teams{gap:0}.app-team,.app-teams{display:flex;align-items:center}.app-team{flex:1 1;gap:7px}.app-team:last-child{justify-content:flex-end;flex-direction:row-reverse}.team-logo{width:22px;height:22px;border-radius:50%;flex-shrink:0}.team-logo-a{background:linear-gradient(135deg,#16a34a,#4ade80)}.team-logo-b{background:linear-gradient(135deg,#eab308,#ef4444)}.team-name{font-size:.6rem;color:#555;display:block}.team-odds{font-size:.8rem;font-weight:700;color:#111;display:block}.app-divider{width:1px;height:28px;background:#e5e7eb;margin:0 8px;flex-shrink:0}.card-body{padding:18px 22px 22px}.card-body h3{font-size:.95rem;font-weight:600;color:#222;margin-bottom:4px}.card-body>span{font-size:.78rem;color:#aaa;font-weight:400}.site-footer{position:fixed;bottom:0;left:0;right:0;z-index:998;height:var(--footer-h);background:#e0e0e0;box-shadow:0 -2px 12px rgba(0,0,0,.08)}.footer-inner{max-width:1280px;height:100%;margin:0 auto;padding:0 40px;display:flex;align-items:center;justify-content:space-between;position:relative;overflow:visible}.footer-credit{font-size:.82rem;color:#777;min-width:140px}.back-to-top{width:48px;height:48px;border-radius:50%;border:1.5px solid #c4c4c4;background:#e0e0e0;display:grid;place-items:center;cursor:pointer;color:#888;transition:border-color .22s,color .22s;position:absolute;left:50%;top:-24px;transform:translateX(-50%)}.back-to-top:hover{border-color:#999;color:#333}.footer-nav{display:flex;gap:28px;min-width:140px;justify-content:flex-end}.footer-nav a{color:#777;text-decoration:none;font-size:.82rem;transition:color .2s}.footer-nav a:hover{color:#333}.stub-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding-top:var(--nav-h);background:var(--light);gap:16px}.stub-page h1{font-size:2.4rem;font-weight:800;letter-spacing:-.03em;color:var(--dark)}.stub-page p{font-size:.95rem;color:#888}.stub-page a{margin-top:8px;font-size:.85rem;color:var(--dark);text-decoration:underline;text-underline-offset:3px}.inner-page{padding-top:var(--nav-h)}.inner-container{max-width:1060px;margin:0 auto;padding:0 40px}.inner-hero{padding:72px 0 56px;border-bottom:1px solid #ebebeb;background:#fff}.inner-lead{font-size:1.05rem;font-weight:300;line-height:1.85;color:#555;max-width:600px;margin-top:20px}.inner-section{padding:72px 0}.bg-white{background:#fff}.bg-light{background:#ebebeb;border-top:1px solid #e2e2e2}.section-label{font-size:.65rem;font-weight:700;letter-spacing:.22em;color:#bbb;margin-bottom:36px;display:flex;align-items:center;gap:16px}.section-label:after{content:"";flex:1 1;height:1px;background:#ddd}.portfolio-featured-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:28px;gap:28px}.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:24px;gap:24px}.port-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 16px rgba(0,0,0,.06);cursor:pointer;transition:transform .3s ease,box-shadow .3s ease;display:flex;flex-direction:column;text-decoration:none}.port-card:hover{transform:translateY(-6px);box-shadow:0 16px 40px rgba(0,0,0,.11)}.port-card-thumb{height:220px;display:flex;align-items:center;justify-content:center}.port-card-thumb-sm{height:160px}.port-card-body{padding:24px 28px 28px;flex:1 1;display:flex;flex-direction:column;gap:6px}.port-card-category{font-size:.65rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#bbb}.port-card-title{font-size:1.05rem;font-weight:700;color:var(--dark);letter-spacing:-.02em;line-height:1.3;margin-top:2px}.port-card-featured .port-card-title{font-size:1.2rem}.port-card-desc{font-size:.88rem;font-weight:300;line-height:1.7;color:#666;flex:1 1;margin-top:4px}.port-card-link{font-size:.8rem;font-weight:600;color:var(--dark);text-decoration:none;border-bottom:1.5px solid #ddd;padding-bottom:1px;transition:border-color .2s;align-self:flex-start;margin-top:12px;cursor:pointer}.port-card-link:hover{border-color:var(--dark)}.blog-filters{display:flex;gap:8px;flex-wrap:wrap;padding-bottom:0}.blog-filter-btn{background:transparent;border:1.5px solid #ddd;border-radius:20px;padding:6px 16px;font-size:.78rem;font-weight:500;cursor:pointer;color:#666;font-family:inherit;transition:all .2s}.blog-filter-btn.active,.blog-filter-btn:hover{background:var(--dark);border-color:var(--dark);color:#fff}.blog-post-featured{display:grid;grid-template-columns:1fr 1fr;grid-gap:48px;gap:48px;align-items:center;background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 2px 20px rgba(0,0,0,.07)}.blog-post-thumb{height:200px;display:flex;align-items:center;justify-content:center}.blog-thumb-lg{height:100%;min-height:280px}.blog-thumb-icon{font-size:3rem;opacity:.3}.blog-post-body{padding:36px 36px 36px 0;display:flex;flex-direction:column;gap:10px}.blog-post-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.blog-post-category{font-size:.62rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#bbb}.blog-post-date,.blog-post-read{font-size:.72rem;color:#bbb}.blog-post-date:before,.blog-post-read:before{content:"·";margin-right:6px}.blog-post-title{font-size:1rem;font-weight:700;color:var(--dark);letter-spacing:-.02em;line-height:1.4}.blog-post-title-lg{font-size:1.35rem}.blog-post-excerpt{font-size:.88rem;font-weight:300;line-height:1.75;color:#666}.blog-post-excerpt-sm{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:24px;gap:24px}.blog-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 14px rgba(0,0,0,.06);cursor:pointer;transition:transform .3s ease,box-shadow .3s ease;display:flex;flex-direction:column}.blog-card:hover{transform:translateY(-5px);box-shadow:0 14px 36px rgba(0,0,0,.11)}.blog-card-body{padding:20px 22px 22px;flex:1 1;display:flex;flex-direction:column;gap:8px}.blog-card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:12px}.learn-group-section:nth-child(odd){background:#fff}.learn-group-section:nth-child(2n){background:#ebebeb;border-top:1px solid #e2e2e2;border-bottom:1px solid #e2e2e2}.learn-group-heading{font-size:1.25rem;font-weight:700;color:var(--dark);letter-spacing:-.02em;margin-bottom:32px;display:flex;align-items:center;gap:12px}.learn-group-emoji{font-size:1.4rem;line-height:1}.learn-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:20px;gap:20px}.learn-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.05);transition:transform .28s ease,box-shadow .28s ease;display:flex;flex-direction:column}.learn-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.1)}.learn-card-accent{height:6px;width:100%}.learn-card-body{padding:18px 20px 22px;display:flex;flex-direction:column;gap:6px;flex:1 1}.learn-card-title{font-size:.9rem;font-weight:700;color:var(--dark);line-height:1.3;letter-spacing:-.01em}.learn-card-author{font-size:.68rem;font-weight:600;color:#bbb;letter-spacing:.04em;text-transform:uppercase}.learn-card-desc{font-size:.82rem;font-weight:300;line-height:1.65;color:#666;margin-top:4px}.contact-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:80px;gap:80px;align-items:start}.contact-sub{font-size:1rem;font-weight:700;color:var(--dark);margin-bottom:24px;letter-spacing:-.02em}.contact-socials{display:flex;flex-direction:column;gap:4px;margin-bottom:40px}.contact-social-row{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:10px;text-decoration:none;color:var(--dark);transition:background .2s}.contact-social-row:hover{background:#f4f4f4}.contact-social-icon{display:flex;align-items:center;color:#555;flex-shrink:0}.contact-social-label{font-size:.9rem;font-weight:500;flex:1 1}.contact-social-arrow{font-size:.85rem;color:#ccc;transition:color .2s,transform .2s}.contact-social-row:hover .contact-social-arrow{color:var(--dark);transform:translateX(3px)}.contact-image-wrap{border-radius:12px;overflow:hidden;background:var(--light);max-height:300px;display:flex;align-items:flex-end;justify-content:center}.contact-photo{max-height:290px;width:auto;object-fit:contain;object-position:bottom;display:block}.contact-form{gap:20px}.contact-form,.form-field{display:flex;flex-direction:column}.form-field{gap:6px}.form-label{font-size:.78rem;font-weight:600;color:#555;letter-spacing:.02em}.form-input{width:100%;background:#f7f7f7;border:1.5px solid #e8e8e8;border-radius:8px;padding:12px 14px;font-size:.9rem;font-family:inherit;color:var(--dark);outline:none;transition:border-color .2s,background .2s}.form-input:focus{border-color:#aaa;background:#fff}.form-textarea{resize:vertical;min-height:140px}.form-submit{align-self:flex-start;background:var(--dark);color:#fff;border:none;border-radius:8px;padding:12px 28px;font-size:.88rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background .2s,opacity .2s}.form-submit:hover{background:#333}.form-submit:disabled{opacity:.5;cursor:not-allowed}.contact-success{display:flex;align-items:center;gap:14px;background:#f0fdf4;border:1.5px solid #a7f3d0;border-radius:10px;padding:20px 24px}.contact-success-icon{width:32px;height:32px;border-radius:50%;background:#059669;color:#fff;display:grid;place-items:center;font-size:.9rem;flex-shrink:0}.contact-success p{font-size:.9rem;font-weight:500;color:#065f46}@media (max-width:1024px){.learn-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:900px){.portfolio-featured-grid{grid-template-columns:1fr}.portfolio-grid{grid-template-columns:1fr 1fr}.blog-post-featured{grid-template-columns:1fr}.blog-thumb-lg{min-height:200px}.blog-post-body{padding:24px}.blog-grid{grid-template-columns:1fr}.learn-grid{grid-template-columns:1fr 1fr}.contact-grid{grid-template-columns:1fr;gap:48px}.contact-image-wrap{display:none}}@media (max-width:600px){.learn-grid,.portfolio-grid{grid-template-columns:1fr}.inner-container{padding:0 20px}}.about-page{padding-top:var(--nav-h)}.about-container{max-width:1060px;margin:0 auto;padding:0 40px}.about-section{padding:80px 0}.page-title{font-size:clamp(2.8rem,6vw,5.2rem);font-weight:800;letter-spacing:-.04em;line-height:1;color:var(--dark);margin-bottom:28px}.about-intro-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:64px;gap:64px;align-items:start}.about-bio{font-size:1.05rem;font-weight:300;line-height:1.85;color:#555;max-width:380px}.about-photo-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto auto;grid-gap:8px;gap:8px}.photo-tile{border-radius:8px;overflow:hidden;position:relative;cursor:pointer;background:#ddd}.tile-portrait{grid-row:span 2;min-height:220px}.tile-landscape{min-height:100px}.photo-img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block;transition:transform .4s ease}.photo-tile:hover .photo-img{transform:scale(1.04)}.photo-caption{position:absolute;inset:0;display:flex;align-items:flex-end;justify-content:flex-start;padding:10px 12px;font-size:.68rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#fff;background:linear-gradient(0deg,rgba(0,0,0,.45) 0,transparent 60%);opacity:0;transition:opacity .3s}.photo-tile:hover .photo-caption{opacity:1}.tile-color-1{background:linear-gradient(135deg,#f59e0b,#fbbf24)}.tile-color-2{background:linear-gradient(135deg,#3b82f6,#60a5fa)}.tile-color-3{background:linear-gradient(135deg,#10b981,#34d399)}.tile-color-4{background:linear-gradient(135deg,#8b5cf6,#a78bfa)}.tile-color-5{background:linear-gradient(135deg,#ef4444,#f87171)}.tile-color-1 .photo-caption,.tile-color-2 .photo-caption,.tile-color-3 .photo-caption,.tile-color-4 .photo-caption,.tile-color-5 .photo-caption{opacity:.9;color:rgba(255,255,255,.9);background:none;font-size:.62rem}.about-skills-section{background:var(--light);border-top:1px solid #e4e4e4;border-bottom:1px solid #e4e4e4}.skills-grid{display:grid;grid-template-columns:1fr auto 1fr;grid-gap:48px;gap:48px;align-items:center}.skills-col h2{font-size:1.1rem;font-weight:700;letter-spacing:-.02em;margin-bottom:20px;color:var(--dark)}.skills-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}.skills-col ul li{font-size:.92rem;font-weight:300;color:#555;display:flex;align-items:center;gap:8px}.skills-col ul li:before{content:"";display:inline-block;width:4px;height:4px;border-radius:50%;background:#bbb;flex-shrink:0}.skills-coder{text-align:right}.skills-coder ul li{flex-direction:row-reverse}.skills-chart-col{display:flex;flex-direction:column;align-items:center;gap:12px}.pie-chart{width:160px;height:160px;flex-shrink:0;filter:drop-shadow(0 4px 16px rgba(0,0,0,.1))}.skills-chart-label{font-size:.62rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#aaa}.about-facts-section{background:var(--white)}.facts-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:80px;gap:80px;align-items:center}.facts-text h2{font-size:1.1rem;font-weight:700;letter-spacing:-.02em;margin-bottom:24px;color:var(--dark)}.facts-list{list-style:none;display:flex;flex-direction:column;gap:12px}.facts-list li{font-size:.92rem;font-weight:300;color:#555;display:flex;align-items:center;gap:10px}.facts-list li:before{content:"";display:inline-block;width:4px;height:4px;border-radius:50%;background:#ccc;flex-shrink:0}.facts-image-col{display:flex;align-items:flex-end;justify-content:center;overflow:hidden;border-radius:12px;background:var(--light);max-height:440px}.facts-img{max-height:420px;width:auto;object-fit:contain;object-position:bottom center;display:block}.about-features-section{background:var(--light);border-top:1px solid #e4e4e4}.feature-cards-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:28px;gap:28px}.feature-card{background:var(--white);border-radius:12px;overflow:hidden;box-shadow:0 2px 16px rgba(0,0,0,.06);transition:transform .3s ease,box-shadow .3s ease}.feature-card:hover{transform:translateY(-6px);box-shadow:0 16px 40px rgba(0,0,0,.11)}.feature-card-image{height:200px}.fc-img-portfolio{background:linear-gradient(135deg,#e8f3fc,#bfdbfe 50%,#dbeafe);position:relative;display:flex;align-items:center;justify-content:center}.fc-img-portfolio:before{content:"◈";font-size:3rem;color:rgba(59,130,246,.18)}.fc-img-learn{background:linear-gradient(135deg,#ecfdf5,#a7f3d0 50%,#d1fae5);display:flex;align-items:center;justify-content:center}.fc-img-learn:before{content:"◎";font-size:3rem;color:rgba(16,185,129,.18)}.fc-img-blog{background:linear-gradient(135deg,#faf5ff,#e9d5ff 50%,#f3e8ff);display:flex;align-items:center;justify-content:center}.fc-img-blog:before{content:"✦";font-size:3rem;color:rgba(139,92,246,.18)}.fc-img-story{background:linear-gradient(135deg,#fff7ed,#fed7aa 50%,#fef3c7);display:flex;align-items:center;justify-content:center}.fc-img-story:before{content:"◉";font-size:3rem;color:rgba(245,158,11,.18)}.feature-card-body{padding:28px 32px 32px}.feature-card-body h2{font-size:1.1rem;font-weight:700;letter-spacing:-.02em;margin-bottom:10px;color:var(--dark)}.feature-card-body p{font-size:.88rem;font-weight:300;line-height:1.75;color:#666;margin-bottom:18px}.feature-link{font-size:.82rem;font-weight:600;color:var(--dark);text-decoration:none;border-bottom:1.5px solid #ddd;padding-bottom:1px;transition:border-color .2s,color .2s}.feature-link:hover{border-color:var(--dark);color:#000}@media (max-width:900px){.about-intro-grid{grid-template-columns:1fr;gap:40px}.about-photo-grid{grid-template-columns:repeat(3,1fr)}.tile-portrait{grid-row:auto}.skills-grid{grid-template-columns:1fr}.skills-coder,.skills-grid{text-align:left}.skills-coder ul li{flex-direction:row}.skills-chart-col{order:-1}.facts-grid{grid-template-columns:1fr}.facts-image-col{display:none}.feature-cards-grid{grid-template-columns:1fr}.hero-copy p,.nav-links{display:none}.hero-copy h1{font-size:clamp(1.8rem,8vw,3rem)}.code-bg{display:none}.work-grid{grid-template-columns:1fr;max-width:420px;margin:0 auto}.footer-nav{display:none}.footer-credit{min-width:unset}}@font-face{font-family:Poppins;font-style:normal;font-weight:300;font-display:swap;src:url(/_next/static/media/6c177e25b87fd9cd-s.woff2) format("woff2");unicode-range:u+0900-097f,u+1cd0-1cf9,u+200c-200d,u+20a8,u+20b9,u+20f0,u+25cc,u+a830-a839,u+a8e0-a8ff,u+11b00-11b09}@font-face{font-family:Poppins;font-style:normal;font-weight:300;font-display:swap;src:url(/_next/static/media/6c9a125e97d835e1-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Poppins;font-style:normal;font-weight:300;font-display:swap;src:url(/_next/static/media/4c285fdca692ea22-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Poppins;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/034d78ad42e9620c-s.woff2) format("woff2");unicode-range:u+0900-097f,u+1cd0-1cf9,u+200c-200d,u+20a8,u+20b9,u+20f0,u+25cc,u+a830-a839,u+a8e0-a8ff,u+11b00-11b09}@font-face{font-family:Poppins;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/fe0777f1195381cb-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Poppins;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/eafabf029ad39a43-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Poppins;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/db911767852bc875-s.woff2) format("woff2");unicode-range:u+0900-097f,u+1cd0-1cf9,u+200c-200d,u+20a8,u+20b9,u+20f0,u+25cc,u+a830-a839,u+a8e0-a8ff,u+11b00-11b09}@font-face{font-family:Poppins;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/f10b8e9d91f3edcb-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Poppins;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/8888a3826f4a3af4-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Poppins;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/29e7bbdce9332268-s.woff2) format("woff2");unicode-range:u+0900-097f,u+1cd0-1cf9,u+200c-200d,u+20a8,u+20b9,u+20f0,u+25cc,u+a830-a839,u+a8e0-a8ff,u+11b00-11b09}@font-face{font-family:Poppins;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/c3bc380753a8436c-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Poppins;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/0484562807a97172-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Poppins;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/29a4aea02fdee119-s.woff2) format("woff2");unicode-range:u+0900-097f,u+1cd0-1cf9,u+200c-200d,u+20a8,u+20b9,u+20f0,u+25cc,u+a830-a839,u+a8e0-a8ff,u+11b00-11b09}@font-face{font-family:Poppins;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/a1386beebedccca4-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Poppins;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/b957ea75a84b6ea7-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Poppins;font-style:normal;font-weight:800;font-display:swap;src:url(/_next/static/media/28485c0de2075f40-s.woff2) format("woff2");unicode-range:u+0900-097f,u+1cd0-1cf9,u+200c-200d,u+20a8,u+20b9,u+20f0,u+25cc,u+a830-a839,u+a8e0-a8ff,u+11b00-11b09}@font-face{font-family:Poppins;font-style:normal;font-weight:800;font-display:swap;src:url(/_next/static/media/5fb25f343c7550ca-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Poppins;font-style:normal;font-weight:800;font-display:swap;src:url(/_next/static/media/7db6c35d839a711c-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Poppins Fallback;src:local("Arial");ascent-override:93.62%;descent-override:31.21%;line-gap-override:8.92%;size-adjust:112.16%}.__className_c70c06{font-family:Poppins,Poppins Fallback;font-style:normal}.__variable_c70c06{--font-poppins:"Poppins","Poppins Fallback"}