.portfolio{--pf-bg: var(--bg);--pf-fg: var(--fg);--pf-muted: var(--fg);--pf-accent: var(--accent);--pf-border: var(--line);color:var(--pf-fg);background:var(--pf-bg);transition:background .3s ease,color .3s ease;scroll-behavior:smooth}.pf-cursor{position:fixed;width:36px;height:36px;border:1px solid var(--pf-accent);border-radius:50%;pointer-events:none;transform:translate(-50%,-50%);z-index:9999;transition:width .2s,height .2s;opacity:.3}.pf-navbar{position:fixed;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:12px 20px;background:transparent;z-index:1000;transition:backdrop-filter .3s}.pf-navbar:before{content:"";position:absolute;top:0;left:0;right:0;height:100%;background:var(--pf-bg);opacity:.9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:-1}.pf-logo-small{position:absolute;left:48px;font-size:24px;font-weight:800;color:var(--pf-fg);text-decoration:none;background:none;border:none;cursor:pointer;padding:0;font-family:inherit;transition:transform .2s ease}.pf-logo-small:hover{transform:scale(1.1)}.logo-name{margin-left:4px;font-size:14px;font-weight:600;letter-spacing:1px;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.pf-nav-links{display:flex;gap:32px;justify-content:center;flex:1}.pf-nav-links a{color:var(--pf-fg);text-decoration:none;font-weight:700;font-size:14px;letter-spacing:.5px;opacity:.8;transition:opacity .2s ease,transform .2s ease;position:relative}.pf-nav-links a:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--pf-accent);transition:width .3s ease}.pf-nav-links a:hover{opacity:1;transform:translateY(-2px)}.pf-nav-links a:hover:after{width:100%}.pf-page-toggle{position:relative;background:transparent;border:0;padding:0;z-index:1002;display:flex;align-items:center;margin-left:16px}.pf-toggle{position:relative;width:70px;height:34px}.pf-toggle input{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;margin:0;cursor:pointer}.pf-toggle .slider{position:absolute;top:0;right:0;bottom:0;left:0;background:#e7d6c926;border:2px solid var(--pf-border);border-radius:9999px;transition:background .25s ease,border-color .25s ease}.pf-toggle .slider:before{content:attr(data-off);position:absolute;width:28px;height:28px;left:3px;top:1px;background:var(--pf-fg);border-radius:50%;box-shadow:0 2px 8px #00000026;display:grid;place-items:center;font-weight:800;font-size:10px;color:var(--pf-bg);letter-spacing:.5px;transition:transform .25s ease,background .25s ease,box-shadow .25s ease,color .25s ease,content .25s ease}.pf-toggle input:active+.slider:before{transform:translate(0) scale(.96)}.pf-toggle input:checked+.slider{background:var(--pf-accent);border-color:var(--pf-accent)}.pf-toggle input:checked+.slider:before{content:attr(data-on);background:var(--pf-bg);transform:translate(36px);color:var(--pf-fg);box-shadow:0 2px 8px #00000040}.pf-toggle input:checked:active+.slider:before{transform:translate(24px) scale(.96)}.pf-toggle input:focus-visible+.slider{outline:2px solid var(--pf-accent);outline-offset:2px}.pf-nav-logo{position:absolute;left:48px;font-size:24px;font-weight:800;z-index:10}.pf-logo-char{color:var(--fg);transition:color .3s ease}.pf-nav-logo:hover .pf-logo-char{color:var(--accent)}.logo-name{color:var(--fg);transition:color .3s ease}.pf-nav-logo:hover .logo-name{color:var(--accent)}.pf-container{max-width:1200px;margin:0 auto;padding:0 32px}.pf-social{position:fixed;left:10px;top:100px;display:grid;gap:10px;border-left:3px solid var(--pf-fg);padding-left:8px;animation:slideInLeft .8s ease}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}.pf-social .ico{color:var(--pf-fg);opacity:.8;text-decoration:none;width:26px;height:26px;display:grid;place-items:center;border:1px solid var(--pf-border);border-radius:4px;background:var(--pf-bg);transition:all .3s ease}.pf-social .ico:hover{opacity:1;transform:translate(4px);border-color:var(--pf-accent)}.pf-hero-section{min-height:calc(100vh - 120px);display:flex;align-items:center;justify-content:center;padding-top:120px;padding-bottom:40px;animation:fadeInUp .8s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.pf-hero{display:grid;grid-template-columns:1.2fr .8fr;gap:40px;align-items:center;justify-content:center;width:100%}.pf-intro{margin:0;text-align:left;animation:fadeInUp 1s ease .2s both}.pf-title{font-size:clamp(28px,5vw,64px);line-height:1.05;margin:0 0 20px;text-align:left}.pf-title .muted{color:var(--pf-muted);font-weight:700;letter-spacing:1px;font-size:.9em}.pf-title .accent{color:var(--pf-accent);font-weight:800}.pf-title .muted-small{color:var(--pf-muted);font-weight:700;letter-spacing:1px;font-size:.5em;opacity:.8}.pf-title .accent-small{color:var(--pf-accent);font-weight:800;font-size:.65em}.pf-sub{margin:0 0 24px;color:var(--pf-muted);text-align:left;font-size:18px;line-height:1.6}.pf-actions{display:flex;align-items:center;gap:16px;margin-top:16px;justify-content:flex-start;flex-wrap:wrap}.pf-actions .btn{display:inline-block;padding:12px 24px;border:2px solid var(--pf-fg);color:var(--pf-fg);text-decoration:none;border-radius:6px;font-weight:700;font-size:14px;transition:all .3s ease;position:relative;overflow:hidden}.pf-actions .btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:var(--pf-fg);transform:translate(-50%,-50%);transition:width .6s ease,height .6s ease;z-index:-1}.pf-actions .btn:hover{color:var(--pf-bg)}.pf-actions .btn:hover:before{width:300px;height:300px}.pf-photo{margin:0;justify-self:end;position:relative;animation:floatIn 1s ease .4s both;display:flex;flex-direction:column;align-items:center}.pf-bee-container{position:fixed;top:0;right:0;bottom:0;left:0;width:100vw;height:100vh;pointer-events:none;z-index:20;mix-blend-mode:normal;opacity:.95}.pf-bee-root{width:100%;height:100%}@keyframes floatIn{0%{opacity:0;transform:translateY(30px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.pf-photo img{width:clamp(280px,35vw,400px);height:auto;border-radius:8px;display:block;filter:grayscale(0%);background:transparent;mix-blend-mode:normal;transition:transform .3s ease,filter .3s ease}.pf-photo img:hover{transform:scale(1.05);filter:grayscale(20%)}.pf-status{position:absolute;left:50%;transform:translate(-50%);bottom:-12px;background:var(--pf-bg);color:var(--pf-fg);font-size:12px;border:1px solid var(--pf-border);border-radius:6px;padding:8px 14px;box-shadow:0 4px 12px #0000001a;white-space:nowrap}.pf-status .dot{display:inline-block;width:8px;height:8px;background:var(--pf-accent);border-radius:50%;margin-right:8px;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.pf-section{padding:80px 0;animation:fadeInUp .8s ease;opacity:0;animation-fill-mode:forwards}.pf-section:nth-child(4){animation-delay:0s}.pf-section:nth-child(5){animation-delay:.1s}.pf-section:nth-child(6){animation-delay:.2s}.pf-section:nth-child(7){animation-delay:.3s}.pf-section:nth-child(8){animation-delay:.4s}.pf-section-title{font-size:32px;font-weight:800;margin-bottom:40px;display:flex;align-items:center;gap:12px;position:relative}.pf-section-title:before{content:"#";color:var(--pf-accent);font-weight:800}.pf-section-title:after{content:"";height:2px;background:var(--pf-border);flex:1}.pf-section-dark{background:#00000008}.pf-about-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:60px;align-items:center}.pf-about-image{width:100%;overflow:hidden;border-radius:12px}.pf-about-image img{width:100%;height:auto;border-radius:12px;object-fit:cover;filter:grayscale(30%);transition:transform .3s ease,filter .3s ease}.pf-about-image img:hover{transform:scale(1.05);filter:grayscale(0%)}.pf-about-content{max-width:none}.pf-about-text{font-size:18px;line-height:1.8;color:var(--pf-muted);margin-bottom:20px}.pf-experience-content{max-width:900px}.pf-timeline-item{border-left:2px solid var(--pf-border);padding:30px 0 30px 30px;position:relative}.pf-timeline-item:before{content:"";position:absolute;left:-7px;top:35px;width:12px;height:12px;border-radius:50%;background:var(--pf-accent);border:2px solid var(--pf-bg)}.pf-timeline-title{font-size:24px;font-weight:800;margin-bottom:10px;color:var(--pf-fg)}.pf-timeline-desc{font-size:16px;line-height:1.6;color:var(--pf-muted)}.pf-sec-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:40px}.view-all{color:var(--pf-fg);text-decoration:none;font-weight:700;border-bottom:2px solid var(--pf-border);padding-bottom:4px;transition:border-color .3s ease}.view-all:hover{border-color:var(--pf-accent)}.pf-grid{display:grid;gap:24px}.pf-projects{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.card{background:var(--pf-bg);border:1px solid var(--pf-border);border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #00000014;transition:all .3s ease;animation:fadeInUp .6s ease both}.card:hover{transform:translateY(-8px);box-shadow:0 12px 24px #00000026;border-color:var(--pf-accent)}.card .thumb{background:linear-gradient(135deg,var(--pf-accent),var(--pf-fg));height:200px;opacity:.8}.card-title{margin:16px 16px 8px;font-size:20px;font-weight:700}.card-desc{margin:0 16px 12px;color:var(--pf-muted);font-size:14px;line-height:1.5}.card-tags{display:flex;gap:8px;padding:0 16px 16px}.card-actions{display:flex;gap:10px;padding:0 16px 16px;flex-wrap:wrap}.card-tags span{font-size:12px;border:1px solid var(--pf-border);padding:4px 10px;border-radius:20px;font-weight:600}.pf-skills{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:40px}.skill-col h4{font-size:20px;font-weight:800;margin-bottom:16px;color:var(--pf-fg)}.skill-col ul{margin:0;padding:0;list-style:none}.skill-col li{color:var(--pf-muted);font-size:16px;line-height:2;padding-left:20px;position:relative}.skill-col li:before{content:"▹";position:absolute;left:0;color:var(--pf-accent);font-weight:700}.pf-contact-content{text-align:center;max-width:700px;margin:0 auto}.pf-contact-text{font-size:18px;line-height:1.8;color:var(--pf-muted);margin-bottom:30px}.pf-contact-links{display:flex;flex-direction:column;gap:16px;align-items:center}.btn-large{padding:14px 28px;font-size:15px}.theme-squares{position:fixed;left:12px;bottom:12px;background:transparent;border:1px solid var(--line);color:var(--fg);padding:8px;border-radius:6px;display:inline-flex;align-items:center;gap:8px;cursor:pointer;z-index:12;transition:all .3s ease}.theme-squares:hover{border-color:var(--accent);transform:scale(1.05)}.theme-squares .cell{width:10px;height:10px;border:1px solid var(--line);background:transparent;transition:background .3s ease}.theme-squares .hint{font-size:11px;opacity:0;transition:opacity .3s}@media (max-width: 900px){.pf-hero{grid-template-columns:1fr;text-align:center}.pf-intro,.pf-title,.pf-sub{text-align:center}.pf-actions{justify-content:center}.pf-photo{justify-self:center}.pf-about-grid{grid-template-columns:1fr;gap:40px}.pf-navbar{padding:12px 24px}.pf-nav-links{gap:12px}.pf-nav-links a{font-size:11px}.pf-nav-logo{left:24px;font-size:20px}.pf-page-toggle{margin-left:8px}.pf-toggle-label{font-size:10px}.pf-toggle{width:48px;height:28px}.pf-toggle .slider:before{width:20px;height:20px;top:4px;left:4px}.pf-toggle input:checked+.slider:before{transform:translate(20px)}.pf-nav-links{gap:8px;font-size:10px}.pf-social{display:none}.pf-projects,.pf-skills{grid-template-columns:1fr}.pf-container{padding:0 20px}.pf-section{padding:60px 0}.pf-section-title{font-size:24px}.pf-bee-container{display:none}}.portfolio .section--contact{padding-top:60px;padding-bottom:40px}.portfolio .section--contact .pf-container,.portfolio .section--contact .section-inner,.portfolio .site-footer .footer-inner{padding-left:80px;max-width:1300px;margin:0 auto}.portfolio .contact-grid{display:grid;grid-template-columns:1.2fr 1fr;grid-template-areas:"eyebrow eyebrow" "title copy";column-gap:10px;align-items:end}.portfolio .contact-eyebrow{grid-area:eyebrow;position:static!important;font-family:inherit;font-size:13px;letter-spacing:2px;text-transform:uppercase;color:var(--pf-muted);margin-bottom:40px;transform:none!important}.portfolio .contact-title{grid-area:title;position:static!important;font-size:clamp(24px,5.2vw,45px)!important;font-weight:800;line-height:1.1!important;color:var(--pf-fg);text-transform:uppercase;margin:0!important;transform:none!important;inset:auto!important}.portfolio .section--contact .pf-section-title:after{display:flex!important;flex:1}.portfolio .contact-copy{grid-area:copy;position:relative!important;top:380px;font-family:Space Mono,monospace;font-size:13px;letter-spacing:1px;text-transform:uppercase;line-height:1.8;color:var(--pf-muted);width:100%;margin-top:40px!important;margin-bottom:0!important;padding-bottom:12px;transform:none!important;inset:auto!important;text-align:left;align-self:end;border-bottom:none!important}.portfolio .contact-copy:after{content:"";display:block;position:absolute;left:0;width:100%;height:1px;background:var(--pf-border);top:320px}.portfolio .contact-copy .line{display:block;position:relative!important;top:220px!important}.portfolio .site-footer{margin-top:180px;border-top:none!important;padding-top:20px;padding-bottom:60px}.portfolio .site-footer .footer-inner{display:grid;grid-template-columns:1.6fr 1fr;align-items:start}.portfolio .footer-left{grid-column:1 / 2}.portfolio .footer-right{grid-column:2 / 3;display:flex;flex-direction:column;gap:16px;padding-top:0}.portfolio .footer-cta{border-top:none;border-bottom:1px solid var(--pf-border);padding:12px 0}.portfolio .pf-section-title:before{display:none!important}@media (max-width: 900px){.portfolio .contact-grid,.portfolio .site-footer .footer-inner{grid-template-columns:1fr;grid-template-areas:"eyebrow" "title" "copy";padding-left:32px}.portfolio .footer-right{margin-top:40px}.pf-toggle{width:48px;height:28px}.pf-toggle .slider:before{width:20px;height:20px;left:4px;top:4px;font-size:9px}.pf-toggle input:checked+.slider:before{transform:translate(20px)}.pf-toggle input:checked:active+.slider:before{transform:translate(20px) scale(.96)}}.github-projects{width:100%;max-width:1200px;margin:0 auto;padding:80px 20px;color:var(--pf-fg)}.section-subtitle{font-size:2.5rem;margin:0 0 20px;color:var(--pf-fg);text-align:center;position:relative;padding-bottom:15px}.section-subtitle:after{content:"";position:absolute;left:50%;bottom:0;transform:translate(-50%);width:80px;height:3px;background:var(--pf-accent)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin:0;padding:0;list-style:none}.project-card{background:var(--pf-bg);border-radius:8px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;height:100%;position:relative;overflow:hidden;border:1px solid var(--pf-border)}.project-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,#3b82f6,#8b5cf6);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.project-card:hover{transform:translateY(-4px);box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a;border-color:#cbd5e0}.project-card:hover:before{transform:scaleX(1)}.project-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;position:relative}.project-link{display:inline-flex;align-items:center;color:var(--pf-fg);font-weight:600;font-size:1.1rem;text-decoration:none;transition:all .2s ease;line-height:1.4}.project-link:hover{color:var(--pf-accent)}.github-icon{margin-right:.5rem;font-size:1.25rem;color:var(--pf-muted);transition:color .2s ease}.project-link:hover .github-icon{color:var(--pf-accent)}.project-description{color:var(--pf-muted);margin:.5rem 0 1rem;line-height:1.6;font-size:.95rem;flex-grow:1}.project-actions{margin:1rem 0;min-height:36px;display:flex;align-items:center;gap:.75rem}.no-demo{color:var(--pf-muted);font-size:.85rem;font-style:italic;opacity:.7}.live-app-btn{display:inline-flex;align-items:center;padding:.5rem 1rem;background:var(--pf-accent);color:var(--pf-bg);border-radius:4px;text-decoration:none;font-weight:500;font-size:.9rem;transition:all .2s ease;border:1px solid transparent;box-shadow:0 2px 4px #0000001a;position:relative;left:10px;top:65px}.live-app-btn:hover{background:transparent;color:var(--pf-accent);border-color:var(--pf-accent)}.live-app-icon{margin-right:.5rem;font-size:.9rem}.project-topics{display:flex;flex-wrap:wrap;gap:8px;margin:1rem 0 .5rem;padding-top:1rem;border-top:1px solid var(--pf-border)}.topic-tag{background:#6366f11a;color:var(--pf-accent);padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500;transition:all .2s ease;border:1px solid var(--pf-border)}.topic-tag:hover{background:var(--pf-accent);color:var(--pf-bg);transform:translateY(-1px)}.loading,.error{text-align:center;padding:3rem 1.5rem;color:var(--pf-muted);grid-column:1 / -1;font-size:1.1rem;background:#ffffff0d;border-radius:8px;border:1px solid var(--pf-border)}.error{color:#ff6b6b;background:#ff6b6b1a}.project-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:1rem;border-top:1px solid var(--pf-border)}.project-stats{display:flex;gap:1.25rem}.project-stats span{display:flex;align-items:center;color:var(--pf-muted);font-size:.85rem;font-weight:500;transition:color .2s ease}.project-stats svg{margin-right:.4rem;width:14px;height:14px;color:var(--pf-muted);transition:color .2s ease}.project-stats span:hover{color:var(--pf-fg)}.project-stats span:hover svg{color:var(--pf-accent)}@media (max-width: 1024px){.projects-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@media (max-width: 768px){.github-projects{padding:60px 20px}.section-subtitle{font-size:2rem}.projects-grid{grid-template-columns:1fr;gap:25px;margin-top:40px}}@media (max-width: 480px){.github-projects{padding:40px 15px}.section-subtitle{font-size:1.75rem}.project-content{padding:20px}.project-link{font-size:1.1rem}.project-description{font-size:.95rem}.project-meta,.project-stats{font-size:.85rem;gap:10px}}.hero{position:relative;display:grid;grid-template-columns:1fr 1fr 1fr;padding:16px 24px 0;height:calc(100vh - 52px);--dx: 0;--dy: 0;--angle: 0deg;overflow:hidden;animation:pageenter .8s ease-out forwards;opacity:0}@keyframes pageenter{0%{opacity:0;transform:translateY(30px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}[data-reveal]{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.2,.8,.2,1),transform .8s cubic-bezier(.2,.8,.2,1);will-change:opacity,transform}[data-reveal].revealed{opacity:1;transform:translateY(0)}.reveal-stagger>*{opacity:0;transform:translateY(20px);transition:opacity .6s cubic-bezier(.2,.8,.2,1),transform .6s cubic-bezier(.2,.8,.2,1)}.reveal-stagger.revealed>*{opacity:1;transform:translateY(0)}.reveal-stagger.revealed>*:nth-child(1){transition-delay:.1s}.reveal-stagger.revealed>*:nth-child(2){transition-delay:.2s}.reveal-stagger.revealed>*:nth-child(3){transition-delay:.3s}.reveal-stagger.revealed>*:nth-child(4){transition-delay:.4s}.side{display:flex;flex-direction:column;justify-content:space-between}.side.left{padding-right:24px}.side.right{padding-left:24px;align-items:flex-end;text-align:right}.side.left .monogram{margin-bottom:auto;transform:translateY(-8px);position:relative;top:5%}.side.right .monogram{margin-top:auto;position:relative;top:5%}.monogram{font-size:clamp(120px,28vw,320px);font-weight:700;line-height:.8;color:var(--accent);cursor:default;position:relative}.portfolio-mode .logo-small{color:#2b190f!important}.monogram:after{display:none;content:none}.tagline,.service{font-weight:700;letter-spacing:2px;margin-bottom:24px}.side.right .service{margin-top:auto;margin-bottom:auto;align-self:auto;transform:translateY(4px)}.side.left .near-divider{margin-top:auto;margin-bottom:auto;align-self:flex-start;transform:translateY(-8px)}.tagline.near-divider{font-size:clamp(16px,4vw,24px);position:relative;top:-12%}.center{position:relative;display:grid;place-items:center}.divider{position:absolute;left:50%;top:55%;width:100vw;height:88px;transform-origin:50% 50%;transform:translate(-50%,-50%);z-index:0;pointer-events:none;overflow:visible}.divider path{stroke:var(--line);stroke-width:1.5;stroke-linecap:round;fill:none;shape-rendering:geometricPrecision;vector-effect:non-scaling-stroke}@media (prefers-reduced-motion: reduce){.divider path{d:path("M 0 10 L 100 10")}}.service{font-size:clamp(16px,4vw,24px);position:relative;top:15%}.image-stack{position:relative;width:min(28vw,260px);aspect-ratio:3 / 4;border-radius:2px;overflow:hidden;filter:none;z-index:1}.image-stack .stack-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;opacity:0;transform:translate(calc(var(--dx) * 6px),calc(var(--dy) * 6px));transition:opacity .5s ease,transform .6s ease}.image-stack .stack-img.active{opacity:1;transform:translate(calc(var(--dx) * 10px),calc(var(--dy) * 10px))}.image-stack .stack-img.fixed{z-index:2}.image-stack.scattering .stack-img{opacity:.75}.image-stack.scattering .stack-img.fixed{opacity:1}.image-stack.scattering .stack-img:not(.fixed){transform:translate(var(--x),var(--y)) scale(var(--s)) rotate(var(--r))}.image-stack.assembled .stack-img{opacity:0}.image-stack.assembled .stack-img.active{opacity:1}.image-card{position:relative;margin:0}.image-card img{width:min(42vw,380px);height:auto;display:block;border-radius:2px;filter:grayscale(100%)}.brand-mark{position:absolute;right:10px;bottom:10px;background:#00000059;color:#fff;font-size:14px;padding:2px 6px;border-radius:4px}.theme-squares{position:fixed;left:12px;bottom:12px;background:transparent;border:1px solid var(--line);color:var(--fg);padding:8px;border-radius:6px;display:inline-flex;align-items:center;gap:8px;cursor:pointer;z-index:12}.theme-squares .grid{display:grid;grid-template-columns:repeat(2,10px);grid-template-rows:repeat(2,10px);gap:3px}.theme-squares .cell{width:10px;height:10px;border:1px solid var(--line);background:transparent}.theme-squares .cell.active{background:var(--fg)}.theme-squares .hint{font-size:11px;opacity:0;transition:opacity .15s}.theme-squares:hover .hint{opacity:.9}.overlay{position:fixed;top:6px;right:6px;bottom:6px;left:6px;background:#eee6db;color:#2b190f;border-radius:8px;box-shadow:0 0 0 2px #2b190f inset;z-index:10;display:grid;grid-template-rows:auto 1fr}.overlay-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;letter-spacing:1px}.overlay-logo{background:none;border:none;color:currentColor;font:inherit;cursor:pointer}.overlay-name{margin-left:6px;font-weight:700}.overlay-close{background:none;border:none;color:currentColor;font:inherit;cursor:pointer}.overlay-nav{display:grid;align-content:start;padding:32px 24px;gap:10px;font-weight:800;color:#2b190f}.overlay-nav a{text-decoration:none;color:inherit;font-size:clamp(48px,12vw,140px);line-height:.9}.overlay-nav a:hover{text-decoration:underline}.section{padding:clamp(48px,12vw,120px) 24px;color:var(--fg);background:var(--bg)}.section+.section{border-top:none}.section .section-inner{max-width:1200px;margin:0 auto;position:relative}.section-title{font-weight:800;letter-spacing:2px;font-size:clamp(18px,3vw,28px);transition:color .3s ease}.section--about{min-height:100vh;display:flex;align-items:center;padding:60px 24px}.section--about .section-inner{max-width:1100px;display:grid;grid-template-columns:.7fr 1.3fr;gap:50px;align-items:start}.about-left{display:flex;flex-direction:column;align-items:center;gap:24px}.about-portrait-wrapper{width:90%;aspect-ratio:4 / 5;background:var(--line);border-radius:40px 40px 100px;overflow:hidden;box-shadow:0 20px 40px #0003}.about-portrait-wrapper img{width:100%;height:100%;object-fit:cover}.about-right{display:grid;grid-template-columns:1.2fr .8fr;gap:40px;color:var(--fg);align-items:start}.about-main-col{display:flex;flex-direction:column;gap:24px}.about-right h1{font-size:clamp(36px,5vw,48px);font-weight:800;margin:0;line-height:1;letter-spacing:-.02em}.about-intro-text{font-size:14.5px;line-height:1.6;opacity:.9;max-width:420px}.about-side-col{display:flex;flex-direction:column;gap:40px}.about-subheading{font-size:15px;letter-spacing:2px;font-weight:900;text-transform:uppercase;margin-bottom:16px;color:var(--accent);border-bottom:2px solid var(--line);padding-bottom:6px;display:inline-block}.about-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.about-list li{font-size:14px;line-height:1.4}.about-list .date{font-weight:800;display:block;font-size:13px;color:var(--fg);margin-bottom:2px;opacity:.9}.about-right-info-stack{display:flex;flex-direction:column;gap:40px}.skills-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.skill-icon-card{aspect-ratio:1/1;background:var(--fg);color:var(--bg);display:grid;place-items:center;border-radius:8px;font-weight:900;font-size:16px;transition:all .3s ease;box-shadow:0 4px 12px #0000001a}.skill-icon-card:hover{transform:translateY(-4px);background:var(--accent)}.portfolio-btn{background:var(--accent);border:4px solid var(--accent);color:var(--bg);padding:12px 32px;font:inherit;font-weight:900;letter-spacing:1px;cursor:pointer;border-radius:8px;transition:all .3s ease;width:90%;text-transform:uppercase;font-size:13px}.portfolio-btn:hover{background:transparent;color:var(--accent)}@media (max-width: 900px){.section--about .section-inner{grid-template-columns:1fr;gap:40px}.about-grid-info{grid-template-columns:1fr}}.section--case{position:relative;padding-top:clamp(64px,14vw,140px);padding-bottom:clamp(64px,14vw,140px)}.section--case .case-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:url(https://images.unsplash.com/photo-1500534314209-a25ddb2bd429?q=80&w=1600&auto=format&fit=crop) center/cover no-repeat;filter:grayscale(100%);opacity:.38;z-index:0}.section--case .section-inner{z-index:1;position:relative}.case-grid{display:grid;grid-template-columns:1.1fr 1fr auto;gap:24px;align-items:start}.eyebrow{font-size:12px;letter-spacing:2px;opacity:.9;margin-bottom:8px}.case-title{font-size:clamp(20px,4vw,42px);letter-spacing:2px;font-weight:800}.services{list-style:none;padding:0;margin:0;display:grid;gap:6px;font-size:14px}.view-project{color:var(--fg);text-decoration:none;border:1px solid var(--line);padding:8px 12px;border-radius:16px;align-self:start;display:inline-block}.view-project:hover{background:#00000026}.work-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:24px;align-items:center}.section--work .section-title{grid-column:1 / 2}.section--work .work-note{grid-column:2 / 3;font-size:18px;line-height:1.5;opacity:.95}.thumb{margin:0}.thumb img{width:140px;height:100px;object-fit:cover;filter:grayscale(100%)}.thumb.left{grid-column:1 / 2;justify-self:start}.thumb.right{grid-column:2 / 3;justify-self:end}.filmstrip{grid-column:1 / -1;display:flex;justify-content:center;gap:8px;margin-top:28px}.filmstrip .frame{width:56px;height:32px;border:1px solid var(--line);background:transparent}.contact-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:24px;align-items:start}.contact-eyebrow{letter-spacing:2px;opacity:.85;margin-bottom:12px;position:relative;top:-40%}.contact-title{font-size:50px;font-weight:800;line-height:1;position:relative;right:58%;top:-15%}.contact-title .line{display:block;white-space:nowrap}.contact-copy{font-size:16px;line-height:1.6;position:relative;left:135%;top:150%}.contact-copy .line{display:block;white-space:nowrap}.contact-email a{color:var(--fg);text-decoration:none;border-bottom:1px solid var(--line);padding-bottom:2px}.contact-email a:hover{text-decoration:underline}.k-wrap{position:relative}.k-name{position:absolute;left:0;right:0;bottom:-24px;font-size:14px;letter-spacing:2px;text-align:right}.site-footer{background:var(--bg);color:var(--fg);padding:24px}.footer-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:end}.footer-left{display:grid;gap:10px;align-content:end}.footer-links{display:flex;gap:18px;font-size:12px;letter-spacing:2px}.footer-links a{color:var(--fg);text-decoration:none;opacity:.9}.footer-links a:hover{text-decoration:underline}.copyright{font-size:12px;opacity:.9}.mini-dots{display:flex;gap:6px}.mini-dots span{width:10px;height:10px;border:1px solid var(--line);display:inline-block}.footer-right{display:grid;gap:14px;justify-items:stretch}.footer-cta{position:relative;display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;text-decoration:none;color:var(--fg);padding:10px 0;border-top:1px solid var(--line);font-weight:700;letter-spacing:1px}.footer-cta .label{font-size:14px}.footer-cta .external-icon{width:14px;height:14px;border:1px solid var(--line);display:inline-block}.footer-cta:hover .label{text-decoration:underline}@media (max-width: 900px){.hero{grid-template-columns:1fr;row-gap:24px;height:auto}.side.right{align-items:flex-start;text-align:left}.divider{position:relative;left:0;right:0;top:auto;width:100%;margin:16px 0;transform:none;height:24px}.center{order:-1}.section--about .section-inner,.work-grid,.contact-grid,.case-grid{grid-template-columns:1fr}.thumb.right{justify-self:start}.footer-inner{grid-template-columns:1fr;gap:18px}.footer-right{order:-1}}.section--gallery{background:var(--bg);color:var(--fg);padding-top:24px;padding-bottom:80px}.scroll-gallery{width:min(1000px,98vw);margin:0 auto;border:1px solid var(--line);border-radius:8px;background:transparent}.sg-viewport{overflow-y:auto;overflow-x:hidden;height:clamp(350px,50vw,450px);scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:var(--accent) transparent}.sg-viewport::-webkit-scrollbar{width:4px}.sg-viewport::-webkit-scrollbar-track{background:transparent}.sg-viewport::-webkit-scrollbar-thumb{background-color:var(--accent);border-radius:20px}.sg-track{display:block}.sg-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:16px;height:auto;min-height:clamp(300px,45vw,400px);align-items:center}.sg-thumb{width:100%;height:clamp(280px,40vw,380px);object-fit:cover;filter:grayscale(100%);border-radius:8px;display:block;transition:filter .5s ease,transform .5s ease,box-shadow .5s ease;border:1px solid transparent}.sg-thumb:hover{filter:grayscale(0%);transform:translateY(-4px) scale(1.02);box-shadow:0 10px 20px #0003;border-color:var(--accent)}.projects-page{--pf-bg: var(--bg);--pf-fg: var(--fg);--pf-muted: var(--fg);--pf-accent: var(--accent);--pf-border: var(--line);color:var(--pf-fg);background:var(--pf-bg)}.pf-projects-page .pf-projects{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.pf-projects.pf-three{grid-template-columns:repeat(3,minmax(0,1fr))}@media (max-width: 900px){.pf-projects.pf-three{grid-template-columns:1fr}}.card-actions .btn{display:inline-block;padding:10px 18px;border:2px solid var(--pf-border);color:var(--pf-fg);text-decoration:none;border-radius:6px;font-weight:700;font-size:13px;transition:all .25s ease}.card-actions .btn:hover{border-color:var(--pf-accent);background:var(--pf-accent);color:var(--pf-bg)}:root{--bg: #2b190f;--fg: #e7d6c9;--accent: #cdb2a9;--line: rgba(231,214,201,.25)}*{box-sizing:border-box}html,body,#root{height:100%}html{scroll-behavior:smooth}body{margin:0;font-family:Space Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;cursor:none}button,a,input,textarea,select{cursor:none}.app{background:var(--bg);color:var(--fg);height:100%;display:grid;grid-template-rows:auto 1fr}.top-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;letter-spacing:1px;position:fixed;left:0;right:0;top:0;z-index:21;background:transparent;border:none}.top-bar .menu{background:none;border:none;color:var(--fg);font:inherit;cursor:pointer}.logo-name{margin-left:-4px;font-size:12px;letter-spacing:2px;opacity:.95}.app .logo-small:hover .logo-name{display:inline}.logo-small{background:none;border:none;color:var(--fg);font:inherit;cursor:pointer}.top-actions{display:flex;align-items:center;gap:16px;margin-left:auto}.top-actions .action{background:none;border:none;color:var(--fg);font:inherit;letter-spacing:2px;cursor:pointer;text-decoration:none}.logo-small{display:flex;align-items:center;gap:6px;transition:all .2s ease;color:var(--fg)}.logo-small:hover{transform:scale(1.05)}.logo-name{color:var(--fg)}.menu{opacity:.9}.app-page-toggle{background:transparent;border:0;padding:0;display:flex;align-items:center;gap:10px}.ui-toggle{position:relative;width:56px;height:32px}.ui-toggle input{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;margin:0;cursor:pointer}.ui-toggle .slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--bg);border:2px solid var(--line);border-radius:9999px;transition:background .25s ease,border-color .25s ease}.ui-toggle .slider:before{content:attr(data-off);position:absolute;width:26px;height:26px;left:3px;top:3px;background:var(--fg);border-radius:50%;box-shadow:0 2px 8px #00000026;display:grid;place-items:center;font-weight:800;font-size:10px;color:var(--bg);letter-spacing:.5px;transition:transform .25s ease,background .25s ease,box-shadow .25s ease,color .25s ease,content .25s ease}.ui-toggle input:active+.slider:before{transform:translate(0) scale(.96)}.ui-toggle input:checked+.slider{background:var(--accent);border-color:var(--accent)}.ui-toggle input:checked+.slider:before{content:attr(data-on);background:var(--bg);transform:translate(24px);color:var(--fg);box-shadow:0 2px 8px #00000040}.ui-toggle input:checked:active+.slider:before{transform:translate(24px) scale(.96)}.ui-toggle input:focus-visible+.slider{outline:2px solid var(--accent);outline-offset:2px}.portfolio-mode{background:#fff7db;color:#1f140c}.portfolio-mode .top-bar{background:transparent;border:none;box-shadow:none}.portfolio-mode .top-actions{display:none}.portfolio-mode .logo-name{display:inline;color:#2b190f}.portfolio-mode .logo-small{color:#2b190f}.cursor-ring{position:fixed;left:0;top:0;width:36px;height:36px;border:1px solid var(--accent);border-radius:50%;pointer-events:none;z-index:20;mix-blend-mode:normal;opacity:.9;transform:translate(-9999px,-9999px);transition:transform .03s linear}.portfolio-mode .cursor-ring{border-color:var(--accent)}@media (max-width: 900px){.ui-toggle{width:48px;height:28px}.ui-toggle .slider:before{width:20px;height:20px;left:4px;top:4px;font-size:9px}.ui-toggle input:checked+.slider:before{transform:translate(20px)}.top-actions{gap:12px}}
