:root{--bg:#f0eae3;--bg-cool:#f2f6f8;--surface:#fff;--fg:#201914;--muted:#69625d;--border:#dbd7d2;--border-cool:#dee2e4;--accent:#d35e2c;--accent-blue:#1779e1;--accent-bg:#0074c9;--green:#31aa40;--dark:#0c1318;--sidebar-bg:#192026;--cream-tint:#fbefea;--radius-sm:8px;--radius-md:12px;--radius-lg:14px;--radius-xl:18px;--gap:20px;--font-body:-apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-display:"Iowan Old Style", "Charter", Georgia, serif;--font-mono:ui-monospace, "SF Mono", Menlo, monospace;--shadow-card:0 8px 40px #00000014;--shadow-soft:0 4px 20px #0000000d}@supports (color:lab(0% 0 0)){:root{--bg:lab(93.06% 1.05107 4.44937);--bg-cool:lab(96.5281% -.82311 -1.65222);--surface:lab(100% 0 0);--fg:lab(9.48198% 2.73063 4.99646);--muted:lab(41.9761% 2.06143 4.02065);--border:lab(86.0938% .692189 2.96071);--border-cool:lab(89.5681% -.822693 -1.65197);--accent:lab(54.7041% 44.8085 50.448);--accent-blue:lab(49.9088% 4.02367 -61.7788);--accent-bg:lab(46.6457% -.178784 -60.0399);--green:lab(61.5358% -50.6384 43.17);--dark:lab(5.27485% -1.59412 -4.15962);--sidebar-bg:lab(11.8532% -2.2426 -4.84933);--cream-tint:lab(95.2714% 3.7697 3.87986)}}*,:before,:after{box-sizing:border-box}html{background:var(--bg);color:var(--fg);font-family:var(--font-body);-webkit-font-smoothing:antialiased;scroll-behavior:smooth}body{background:var(--bg);min-height:100vh;color:var(--fg);margin:0}a{color:inherit}button,input,textarea,select{font:inherit}.kicker,.section-label,.section-header,.card-num,.blog-tag,.b-tag,.panel-title{letter-spacing:.18em;text-transform:uppercase}.kicker{color:var(--accent);font-size:11px;font-weight:600}.card{background:var(--surface);border-radius:var(--radius-xl);color:var(--fg);flex-direction:column;display:flex;position:relative;overflow:hidden}.card-padded{padding:32px}.button,.btn-accent{cursor:pointer;border:0;justify-content:center;align-items:center;gap:8px;font-size:13px;font-weight:600;text-decoration:none;transition:background .15s,border-color .15s,box-shadow .15s,color .15s;display:inline-flex}.button-primary,.btn-accent{background:var(--accent);color:#fff;border-radius:999px;padding:10px 24px}.button-muted{background:var(--bg);border-radius:var(--radius-sm);color:var(--fg);padding:8px 16px}.button:hover,.btn-accent:hover{box-shadow:0 2px 12px #0000000f}.avatar{aspect-ratio:1;border-radius:50%;flex-shrink:0;place-items:center;font-weight:800;display:grid}.avatar-sm{width:80px;height:80px}.stack-16{flex-direction:column;gap:16px;display:flex}.index-page{max-width:1080px;margin:0 auto;padding:80px 32px}.index-header{margin-bottom:64px}.index-header .kicker{margin-bottom:16px}.index-header h1{font-family:var(--font-display);letter-spacing:-.02em;margin:0 0 16px;font-size:clamp(32px,5vw,48px);font-weight:700;line-height:1.15}.index-header p{color:var(--muted);max-width:560px;margin:0;font-size:17px;line-height:1.7}.direction-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:24px;display:grid}.direction-card{background:var(--surface);color:var(--fg);border-radius:16px;flex-direction:column;text-decoration:none;transition:box-shadow .2s,transform .2s;display:flex;overflow:hidden}.direction-card:hover{box-shadow:var(--shadow-card);transform:translateY(-2px)}.card-preview{--preview-scale:.5;--preview-inverse:2;border-bottom:1px solid var(--border);height:clamp(240px,56.25cqw,360px);position:relative;overflow:hidden;container-type:inline-size}.card-preview iframe{height:calc(100% * var(--preview-inverse));pointer-events:none;transform:scale(var(--preview-scale));transform-origin:0 0;width:calc(100% * var(--preview-inverse));border:0;position:absolute;top:0;left:0}.card-body{flex-direction:column;flex:1;gap:8px;padding:24px;display:flex}.card-body .card-num{color:var(--accent);letter-spacing:.15em;font-size:11px;font-weight:700}.card-body h2{letter-spacing:-.01em;margin:0;font-size:20px;font-weight:700}.card-body p{color:var(--muted);margin:0;font-size:14px;line-height:1.6}.tags{flex-wrap:wrap;gap:6px;margin-top:auto;padding-top:12px;display:flex}.tag{background:var(--bg);color:var(--muted);border-radius:6px;padding:4px 10px;font-size:11px;font-weight:500}.index-footer{border-top:1px solid var(--border);color:var(--muted);text-align:center;margin-top:64px;padding-top:32px;font-size:13px}.bento-page{max-width:1280px;min-height:100vh;padding:var(--gap);margin:0 auto}.bento{gap:var(--gap);grid-template-columns:repeat(12,minmax(0,1fr));display:grid}.span-8{grid-column:span 8}.span-6{grid-column:span 6}.span-4{grid-column:span 4}.span-3{grid-column:span 3}.span-12{grid-column:span 12}.row-2{grid-row:span 2}.hero-card{color:#fff;background:linear-gradient(135deg,#313c44,#192424);background:linear-gradient(135deg,lab(24.619% -3.01947 -6.47737),lab(13.1481% -4.73355 -1.96949));justify-content:flex-end;min-height:380px;padding:40px}.hero-card .hero-label{letter-spacing:.2em;opacity:.6;text-transform:uppercase;margin-bottom:12px;font-size:11px}.hero-card h1{letter-spacing:-.02em;margin:0;font-size:clamp(36px,5vw,56px);font-weight:800;line-height:1.05}.hero-card .hero-sub{opacity:.7;max-width:420px;margin:12px 0 0;font-size:17px;line-height:1.5}.social-card{background:var(--accent-bg);color:#fff;text-align:center;justify-content:center;align-items:center;gap:16px;padding:32px}.social-card .avatar{color:#fff;background:#b3c0ca;background:lab(76.8275% -3.19049 -6.55433);border:3px solid #ffffff4d;width:72px;height:72px;font-size:28px}.social-card p,.bio-card p,.expertise-card p,.project-card p,.newsletter-card p,.blog-card p,.contact-card p{color:var(--muted);margin:0;line-height:1.6}.social-card p{color:#ffffffd9;font-size:14px}.bio-card h3,.newsletter-card h4,.contact-card h4{margin:0 0 16px;font-size:15px;font-weight:700}.bio-card p{font-size:14px;line-height:1.7}.section-label{color:var(--muted);margin:0 0 12px;font-size:11px}.expertise-card,.project-card,.testimonial-card,.blog-card,.now-card,.contact-card{padding:28px 32px}.expertise-card{gap:8px}.expertise-card .icon{background:#f8e7e1;background:lab(92.921% 5.04288 5.18521);border-radius:10px;place-items:center;width:40px;height:40px;margin-bottom:4px;font-size:18px;display:grid}.expertise-card h4,.project-card h4,.blog-card h4,.now-card h4{margin:0;font-weight:700}.expertise-card h4{font-size:15px}.expertise-card p,.project-card p,.newsletter-card p,.blog-card p{font-size:13px}.project-card .project-role{color:var(--accent);margin-bottom:4px;font-size:12px;font-weight:600}.project-card h4{margin-bottom:8px;font-size:17px}.project-card .stat{color:var(--fg);letter-spacing:-.02em;margin-top:16px;font-size:24px;font-weight:800}.project-card .stat-label{color:var(--muted);letter-spacing:.1em;text-transform:uppercase;font-size:11px;font-weight:400}.newsletter-card{background:var(--cream-tint);gap:12px;padding:32px}.newsletter-card .nl-icon{color:var(--accent);font-size:28px}.photo-card{color:var(--muted);letter-spacing:.1em;text-transform:uppercase;background:#dbd7d0;background:lab(86.0969% .871837 3.70513);place-items:center;min-height:200px;font-size:12px;display:grid}.gallery-card{padding:12px}.gallery-card-header{padding:20px 20px 12px}.gallery-masonry{border-radius:var(--radius-xl);grid-template-rows:140px 140px;grid-template-columns:repeat(3,1fr);gap:8px;display:grid;overflow:hidden}.gallery-box{color:var(--muted);cursor:pointer;letter-spacing:.08em;text-align:center;text-transform:uppercase;background:#e1ddd8;background:lab(88.4138% .691712 2.96041);border:0;border-radius:8px;place-items:center;font-size:11px;transition:opacity .15s;display:grid}.gallery-box:hover{opacity:.8}.gallery-masonry .tall{grid-row:span 2}.skills-wrap{flex-wrap:wrap;gap:8px;margin-top:4px;display:flex}.skill-pill,.skill-tag{background:var(--bg);color:var(--fg);align-items:center;font-weight:600;display:inline-flex}.skill-pill{border-radius:999px;gap:6px;padding:7px 16px;font-size:12px}.skill-pill .dot{border-radius:50%;width:6px;height:6px}.dot-1{background:var(--accent)}.dot-2{background:var(--accent-blue)}.dot-3{background:var(--green)}.testimonial-card{justify-content:space-between;gap:16px}.testimonial-card .quote-mark{color:var(--accent);opacity:.5;font-family:Georgia,serif;font-size:32px;line-height:1}.testimonial-card blockquote{color:var(--fg);margin:0;font-size:14px;font-style:italic;line-height:1.7}.testimonial-card .attribution,.blog-card .blog-meta{color:var(--muted);font-size:12px}.testimonial-card .attribution strong{color:var(--fg)}.blog-card{gap:12px}.blog-card .blog-tag{color:var(--accent);letter-spacing:.12em;font-size:10px;font-weight:700}.blog-card h4{font-size:16px;line-height:1.35}.blog-card .blog-meta{opacity:.7;font-size:11px}.now-card{gap:16px}.now-card .now-dot{background:var(--green);border-radius:50%;width:8px;height:8px;margin-right:8px;animation:2s ease-in-out infinite pulse;display:inline-block}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.now-card ul{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.now-card li{color:var(--muted);padding-left:16px;font-size:13px;position:relative}.now-card li:before{color:var(--border);content:"—";position:absolute;left:0}.experience-mini{flex-direction:column;gap:14px;display:flex}.experience-mini div div{font-size:13px;font-weight:700}.experience-mini span{color:var(--muted);font-size:12px}.contact-links,.contact-grid,.contact-row{flex-wrap:wrap;gap:8px;display:flex}.contact-links a,.contact-grid a{background:var(--bg);color:var(--fg);border-radius:999px;align-items:center;gap:6px;padding:8px 16px;font-size:12px;font-weight:600;text-decoration:none;transition:background .15s,box-shadow .15s;display:inline-flex}.contact-links a:hover{background:var(--border)}.marquee-wrap{grid-column:1/-1;padding:20px 0;overflow:hidden}.marquee{gap:48px;width:max-content;animation:25s linear infinite scroll;display:flex}@keyframes scroll{to{transform:translate(-50%)}}.marquee span{color:var(--muted);letter-spacing:.25em;opacity:.5;text-transform:uppercase;white-space:nowrap;font-size:14px}.marquee .dot{color:var(--accent);opacity:.6}.split-shell{min-height:100vh;display:flex}.sidebar{background:var(--sidebar-bg);color:#fff;flex-direction:column;flex-shrink:0;gap:32px;width:340px;height:100vh;padding:48px 36px;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar .avatar{color:#ffffffb3;background:#3e4952;background:lab(30.4209% -3.0582 -6.49335);width:96px;height:96px;font-size:36px}.sidebar h1{letter-spacing:-.02em;margin:0;font-size:28px;font-weight:800;line-height:1.15}.sidebar .tagline{opacity:.6;margin:-16px 0 0;font-size:14px;line-height:1.6}.sidebar nav{flex-direction:column;gap:6px;margin-top:auto;display:flex}.sidebar nav a{color:#ffffff80;letter-spacing:.05em;border-bottom:1px solid #ffffff0f;padding:8px 0;font-size:13px;text-decoration:none;transition:color .15s}.sidebar nav a:hover{color:#fff}.social-row{flex-wrap:wrap;gap:12px;display:flex}.social-row a{color:#fff6;border:1px solid #ffffff1a;border-radius:999px;padding:6px 14px;font-size:11px;text-decoration:none;transition:all .15s}.social-row a:hover{color:#fff;border-color:#ffffff4d}.now-status{opacity:.5;font-size:12px;line-height:1.6}.now-status strong{color:#45ba50;color:lab(67.3528% -50.581 42.6409);opacity:1}.split-main{background:var(--bg);flex:1;padding:56px 64px;overflow-y:auto}.section{max-width:900px;margin:0 auto 56px}.split-main .section{margin-left:0}.section-header{border-bottom:1px solid var(--border);color:var(--muted);margin-bottom:24px;padding-bottom:12px;font-size:11px}.about-text{color:var(--fg);max-width:640px;margin:0;font-size:20px;font-weight:400;line-height:1.7}.about-text strong{color:var(--accent);font-weight:700}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;display:grid}.project,.proj-card{background:var(--surface);border-radius:var(--radius-lg);padding:28px}.project .role,.proj-card .proj-role,.project .proj-role{color:var(--accent);letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px;font-size:11px;font-weight:700}.project h3,.proj-card h3{letter-spacing:-.01em;margin:0 0 8px;font-size:18px;font-weight:700}.proj-card h3{font-family:var(--font-display)}.project p,.proj-card p{color:var(--muted);margin:0 0 16px;font-size:13px;line-height:1.6}.metric{letter-spacing:-.02em;font-size:28px;font-weight:800}.metric-label{color:var(--muted);letter-spacing:.08em;text-transform:uppercase;font-size:11px}.timeline{flex-direction:column;max-width:600px;display:flex}.tl-item{border-bottom:1px solid var(--border);grid-template-columns:100px 1fr;gap:24px;padding:20px 0;display:grid}.tl-item:last-child{border-bottom:0}.tl-year{color:var(--muted);font-variant-numeric:tabular-nums;padding-top:2px;font-size:12px}.tl-content h4{margin:0 0 2px;font-size:15px;font-weight:700}.tl-role{color:var(--accent);font-size:12px;font-weight:600}.tl-content p{color:var(--muted);margin:6px 0 0;font-size:13px;line-height:1.5}.gallery-pairs{grid-template-columns:1fr 1fr;gap:12px;display:grid}.gallery-pairs .gallery-box{border-radius:var(--radius-lg);background:#e7e4e0;background:lab(90.7306% .514656 2.21765);height:160px}.gallery-pairs .wide{grid-column:span 2;height:200px}.skills-grouped{flex-direction:column;gap:24px;display:flex}.skill-group-label{color:var(--accent);letter-spacing:.15em;text-transform:uppercase;margin-bottom:8px;font-size:10px;font-weight:700}.skill-group-items{flex-wrap:wrap;gap:6px;display:flex}.skill-tag{border-radius:8px;padding:6px 14px;font-size:12px}.testimonial-split{background:var(--surface);border-radius:var(--radius-lg);grid-template-columns:80px 1fr;align-items:start;gap:20px;padding:24px;display:grid}.testimonial-split .avatar{color:var(--muted);background:#e1ddd8;background:lab(88.4138% .691712 2.96041);font-size:24px}.testimonial-split blockquote,.t-metric-item blockquote{color:var(--fg);margin:0 0 8px;font-size:14px;font-style:italic;line-height:1.7}.t-attr{color:var(--muted);font-size:12px}.t-attr strong{color:var(--fg)}.blog-feed{flex-direction:column;gap:20px;display:flex}.blog-entry{border-bottom:1px solid var(--border);grid-template-columns:1fr auto;align-items:start;gap:16px;padding-bottom:20px;display:grid}.blog-entry:last-child{border-bottom:0;padding-bottom:0}.b-tag{color:var(--accent);letter-spacing:.1em;margin-bottom:4px;font-size:10px;font-weight:700}.blog-entry h4{margin:0 0 4px;font-size:16px;font-weight:700;line-height:1.35}.blog-entry p{color:var(--muted);margin:0;font-size:13px;line-height:1.5}.b-meta{color:var(--muted);opacity:.7;white-space:nowrap;padding-top:2px;font-size:11px}.contact-intro{color:var(--muted);max-width:480px;margin:0 0 20px;font-size:15px;line-height:1.6}.contact-grid{gap:12px}.contact-grid a{border-radius:var(--radius-lg);padding:14px 24px;font-size:14px}.contact-grid a:hover{box-shadow:0 2px 12px #0000000f}.contact-grid a.primary{background:var(--accent);color:#fff}.dashboard-page{background:var(--bg-cool);min-height:100vh;padding-bottom:48px}.topbar{background:var(--surface);border-bottom:1px solid var(--border-cool);z-index:100;justify-content:space-between;align-items:center;padding:16px 32px;display:flex;position:sticky;top:0}.topbar .logo{letter-spacing:-.03em;font-size:16px;font-weight:800}.topbar nav{gap:8px;display:flex}.topbar nav a{color:var(--muted);border-radius:8px;padding:6px 14px;font-size:13px;text-decoration:none;transition:all .12s}.topbar nav a:hover,.topbar nav a.active{background:var(--bg-cool);color:var(--fg)}.topbar .cta{background:var(--fg);color:var(--surface);border-radius:8px;padding:8px 20px;font-size:12px;font-weight:600;text-decoration:none}.dashboard{grid-template-columns:repeat(12,minmax(0,1fr));gap:16px;max-width:1200px;margin:0 auto;padding:28px 32px;display:grid}.panel{background:var(--surface);border:1px solid var(--border-cool);border-radius:var(--radius-md);padding:24px}.col-8{grid-column:span 8}.col-6{grid-column:span 6}.col-4{grid-column:span 4}.col-3{grid-column:span 3}.col-12{grid-column:span 12}.panel-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.panel-title{color:var(--muted);letter-spacing:.1em;font-size:12px;font-weight:700}.panel-badge{font-family:var(--font-mono);border-radius:999px;padding:3px 10px;font-size:10px;font-weight:600}.badge-green{color:#095717;color:lab(31.8109% -33.8088 29.2465);background:#dbf3db;background:lab(93.5632% -11.1774 8.71228)}.badge-accent{color:var(--accent);background:#ffe4d9;background:lab(92.7958% 10.208 10.4673)}.identity{align-items:flex-start;gap:24px;display:flex}.identity .avatar{color:var(--muted);background:#e2ddd7;background:lab(88.4169% .871062 3.70467);width:80px;height:80px;font-size:32px}.identity h1{letter-spacing:-.02em;margin:0;font-size:26px;font-weight:800}.role-line,.identity .bio{color:var(--muted);font-size:14px}.role-line{margin-top:4px}.identity .bio{max-width:480px;margin:12px 0 0;line-height:1.6}.stats-row{display:flex}.stat-cell{text-align:center;flex:1;padding:20px 16px}.stat-cell+.stat-cell{border-left:1px solid var(--border-cool)}.stat-cell .value{font-variant-numeric:tabular-nums;letter-spacing:-.02em;font-size:28px;font-weight:800}.stat-cell .label{color:var(--muted);letter-spacing:.08em;text-transform:uppercase;margin-top:4px;font-size:11px}.project-row{border-bottom:1px solid var(--border-cool);align-items:center;gap:16px;padding:16px 0;display:flex}.project-row:last-child{border-bottom:0}.p-icon{background:var(--bg-cool);border-radius:10px;flex-shrink:0;place-items:center;width:40px;height:40px;font-size:16px;display:grid}.p-info{flex:1}.p-name{font-size:14px;font-weight:700}.p-desc{color:var(--muted);margin-top:2px;font-size:12px}.p-meta{color:var(--muted);font-family:var(--font-mono);text-align:right;font-size:11px}.exp-table,.tools-table{border-collapse:collapse;width:100%;font-size:13px}.exp-table th,.tools-table th{border-bottom:1px solid var(--border-cool);color:var(--muted);letter-spacing:.08em;text-align:left;text-transform:uppercase;padding:8px 0;font-size:11px;font-weight:600}.exp-table td,.tools-table td{vertical-align:top;border-bottom:1px solid #edeff0;border-bottom:1px solid lab(94.205% -.495374 -.992215);padding:12px 0}.exp-table tr:last-child td,.tools-table tr:last-child td{border-bottom:0}.role-col,.cat-col{color:var(--accent);font-size:12px;font-weight:600}.year-col{color:var(--muted);font-family:var(--font-mono);font-size:12px}.now-list{flex-direction:column;gap:12px;margin:0;padding:0;list-style:none;display:flex}.now-list li{color:var(--fg);align-items:flex-start;gap:10px;font-size:13px;line-height:1.5;display:flex}.now-list .dot{background:var(--green);border-radius:50%;flex-shrink:0;width:7px;height:7px;margin-top:6px}.gallery-strip{gap:8px;padding-bottom:4px;display:flex;overflow-x:auto}.gallery-strip .g-thumb{background:#e4e8eb;background:lab(91.8897% -.985682 -1.98157);border-radius:8px;flex-shrink:0;width:140px;height:100px}.skill-bars{flex-direction:column;gap:14px;display:flex}.skill-bar-row{align-items:center;gap:12px;display:flex}.skill-bar-label{flex-shrink:0;width:120px;font-size:12px;font-weight:600}.skill-bar-track{background:var(--bg-cool);border-radius:3px;flex:1;height:6px;overflow:hidden}.skill-bar-fill{border-radius:3px;height:100%}.bar-accent{background:var(--accent)}.bar-green{background:var(--green)}.bar-blue{background:var(--accent-blue)}.skill-bar-value{color:var(--muted);font-family:var(--font-mono);text-align:right;width:32px;font-size:11px}.testimonial-metric{flex-direction:column;gap:16px;display:flex}.t-metric-item{border-bottom:1px solid #edeff0;border-bottom:1px solid lab(94.205% -.495374 -.992215);grid-template-columns:48px 1fr;align-items:start;gap:14px;padding:14px 0;display:grid}.t-metric-item:last-child{border-bottom:0}.t-metric-score{color:var(--accent);font-family:var(--font-mono);background:#ffe4d9;background:lab(92.7958% 10.208 10.4673);border-radius:10px;place-items:center;width:48px;height:48px;font-size:18px;font-weight:800;display:grid}.tools-table .cat-col{letter-spacing:.06em;text-transform:uppercase;font-size:11px}.tool-name{font-weight:600}.tool-note{color:var(--muted);font-size:12px}.contact-list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.contact-list li a{background:var(--bg-cool);color:var(--fg);border-radius:8px;justify-content:space-between;align-items:center;padding:12px 16px;font-size:13px;font-weight:600;text-decoration:none;transition:background .12s;display:flex}.contact-list li a:hover{background:var(--border-cool)}.contact-list .arrow{color:var(--muted);font-size:14px}.narrative-page{background:var(--bg)}.nav{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:100;background:#ede8e0d9;justify-content:space-between;align-items:center;padding:16px 48px;display:flex;position:fixed;top:0;left:0;right:0}.nav .name{font-family:var(--font-display);font-size:18px;font-weight:700}.nav-links{gap:28px;display:flex}.nav-links a{color:var(--muted);font-size:13px;text-decoration:none;transition:color .15s}.nav-links a:hover{color:var(--fg)}.hero{flex-direction:column;justify-content:center;max-width:900px;min-height:100vh;margin:0 auto;padding:120px 48px 80px;display:flex}.hero .kicker{letter-spacing:.25em;margin-bottom:24px;font-size:12px}.hero h1{font-family:var(--font-display);letter-spacing:-.02em;max-width:720px;margin:0;font-size:clamp(42px,6vw,72px);font-weight:700;line-height:1.1}.hero .lead{color:var(--muted);max-width:560px;margin:28px 0 0;font-size:20px;line-height:1.7}.hero .scroll-hint{color:var(--muted);letter-spacing:.2em;opacity:.5;text-transform:uppercase;margin-top:64px;font-size:11px}.narrative-page .section{max-width:900px;margin:0 auto;padding:80px 48px}.narrative-page .section-label{color:var(--accent);margin-bottom:32px;font-weight:600}.bleed{background:var(--dark);color:#fff;text-align:center;width:100%;padding:100px 48px}.bleed .pull-quote{font-family:var(--font-display);max-width:720px;margin:0 auto;font-size:clamp(28px,4vw,44px);font-style:italic;line-height:1.35}.bleed .attribution{opacity:.5;margin:24px 0 0;font-size:13px}.about-body{grid-template-columns:200px 1fr;align-items:start;gap:48px;display:grid}.about-avatar{color:var(--muted);background:#dbd7d0;background:lab(86.0969% .871837 3.70513);border-radius:50%;place-items:center;width:160px;height:160px;font-size:56px;font-weight:800;display:grid}.narrative-page .about-text{font-size:18px;line-height:1.8}.narrative-timeline{max-width:none;padding-left:40px;display:block;position:relative}.narrative-timeline:before{background:var(--border);content:"";width:1px;position:absolute;top:8px;bottom:8px;left:7px}.tl-entry{padding-bottom:48px;position:relative}.tl-entry:last-child{padding-bottom:0}.tl-entry:before{background:var(--accent);border:2px solid var(--bg);content:"";border-radius:50%;width:9px;height:9px;position:absolute;top:8px;left:-33px}.tl-entry .year{color:var(--muted);font-variant-numeric:tabular-nums;margin-bottom:6px;font-size:12px}.tl-entry h3{font-family:var(--font-display);margin:0 0 4px;font-size:20px;font-weight:700}.tl-entry .role{color:var(--accent);margin-bottom:8px;font-size:13px;font-weight:600}.tl-entry p{color:var(--muted);max-width:520px;margin:0;font-size:15px;line-height:1.7}.stat-inline{color:var(--fg);letter-spacing:-.02em;align-items:baseline;gap:6px;margin-top:12px;font-size:24px;font-weight:800;display:inline-flex}.stat-inline span{color:var(--muted);letter-spacing:.06em;text-transform:uppercase;font-size:12px;font-weight:400}.narrative-page .projects-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));margin-top:8px}.proj-card{transition:box-shadow .15s}.proj-card:hover{box-shadow:var(--shadow-soft)}.now-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;display:grid}.now-item{background:var(--surface);border-radius:var(--radius-lg);padding:24px 24px 24px 36px;font-size:14px;line-height:1.6;position:relative}.now-item:before{background:var(--green);content:"";border-radius:50%;width:6px;height:6px;position:absolute;top:30px;left:20px}.gallery-bleed{background:#e7e4e0;background:lab(90.7306% .514656 2.21765);width:100%;padding:0}.gallery-bleed .g-main{border-radius:0;width:100%;height:400px}.gallery-bleed .g-strip{background:#dbd7d2;background:lab(86.0938% .692189 2.96071);gap:4px;padding:4px;display:flex}.gallery-bleed .g-sm{background:#e0ddda;background:lab(88.4106% .514925 2.21779);border-radius:0;flex:1;height:80px}.skills-prose{color:var(--fg);max-width:640px;margin:0;font-size:18px;line-height:1.8}.skill-highlight{white-space:nowrap;background:#f8e7e1;background:lab(92.921% 5.04288 5.18521);border-radius:4px;padding:2px 10px;font-weight:600;display:inline}.testimonial-series,.blog-excerpts{flex-direction:column;gap:40px;display:flex}.t-pull{border-left:3px solid var(--accent);padding-left:28px}.t-pull blockquote{color:var(--fg);font-family:var(--font-display);margin:0 0 12px;font-size:22px;font-style:italic;line-height:1.5}.blog-excerpt{max-width:640px}.blog-excerpt h3{font-family:var(--font-display);margin:0 0 12px;font-size:24px;font-weight:700;line-height:1.3}.blog-excerpt p{color:var(--muted);margin:0 0 8px;font-size:16px;line-height:1.7}.read-more{color:var(--accent);font-size:13px;font-weight:600;text-decoration:none}.read-more:hover{text-decoration:underline}.contact-section{background:var(--dark);color:#fff;text-align:center;padding:80px 48px}.contact-section h2{font-family:var(--font-display);margin:0 0 12px;font-size:36px;font-weight:700}.contact-section .sub{opacity:.6;margin:0 0 36px;font-size:16px}.contact-section .contact-links,.contact-row{justify-content:center}.contact-section .contact-links a{color:#fff;background:0 0;border:1px solid #ffffff26;padding:12px 28px}.contact-section .contact-links a:first-child{background:var(--accent);border-color:var(--accent)}.contact-section .contact-links a:hover{background:#ffffff14;border-color:#ffffff4d}.lightbox-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);opacity:0;pointer-events:none;z-index:9999;background:#000000bf;justify-content:center;align-items:center;transition:opacity .25s;display:flex;position:fixed;inset:0}.lightbox-overlay.active{opacity:1;pointer-events:auto}.lightbox-content{color:var(--muted);letter-spacing:.1em;text-transform:uppercase;border-radius:16px;place-items:center;width:min(80vw,900px);height:min(70vh,640px);font-size:18px;transition:transform .25s;display:grid;position:relative;transform:scale(.9)}.lightbox-overlay.active .lightbox-content{transform:scale(1)}.lightbox-close{color:#fff;cursor:pointer;background:#ffffff26;border:0;border-radius:50%;place-items:center;width:32px;height:32px;font-size:18px;transition:background .15s;display:grid;position:absolute;top:-40px;right:0}.lightbox-close:hover{background:#ffffff4d}.lightbox-caption{color:#ffffffb3;letter-spacing:.08em;text-align:center;font-size:13px;position:absolute;bottom:-36px;left:0;right:0}.ds-page{max-width:1120px;margin:0 auto;padding:64px 32px}.ds-page h1{font-family:var(--font-display);margin:0 0 16px;font-size:48px;line-height:1.1}.ds-page>p{color:var(--muted);max-width:680px;margin:0 0 48px;font-size:17px;line-height:1.7}.ds-section{border-top:1px solid var(--border);padding:32px 0}.ds-section h2{letter-spacing:.16em;text-transform:uppercase;margin:0 0 20px;font-size:14px}.swatch-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;display:grid}.swatch{background:var(--surface);border-radius:var(--radius-md);overflow:hidden}.swatch-color{height:80px}.swatch-body{padding:12px}.swatch-body strong{font-size:13px;display:block}.swatch-body span{color:var(--muted);font-family:var(--font-mono);font-size:11px}.component-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;display:grid}.form-demo{gap:12px;display:grid}.input{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--fg);padding:12px 14px;font-size:14px}.input:focus{border-color:var(--accent);outline:2px solid #ffe4d9;outline:2px solid lab(92.7958% 10.208 10.4673)}@media (max-width:1024px){.span-8{grid-column:span 12}.span-6,.span-4,.span-3{grid-column:span 6}.col-8,.col-6,.col-4{grid-column:span 12}.col-3{grid-column:span 6}}@media (max-width:900px){.split-shell{flex-direction:column}.sidebar{flex-flow:wrap;align-items:center;width:100%;height:auto;padding:32px 24px;position:relative}.sidebar .avatar{width:64px;height:64px;font-size:24px}.sidebar h1{font-size:22px}.sidebar .tagline{margin-top:0}.sidebar nav{flex-direction:row;gap:16px;width:100%;margin-top:0}.sidebar nav a{border-bottom:0}.split-main{padding:32px 20px}}@media (max-width:768px){.nav{padding:14px 20px}.nav-links{gap:16px}.hero{padding:100px 20px 60px}.narrative-page .section{padding:60px 20px}.bleed,.contact-section{padding:64px 20px}.about-body{grid-template-columns:1fr;gap:24px}.about-avatar{width:100px;height:100px;font-size:36px}}@media (max-width:720px){.index-page{padding:48px 16px}.direction-grid{grid-template-columns:1fr}.card-preview{--preview-scale:.42;--preview-inverse:2.381;height:clamp(220px,56.25cqw,340px)}}@media (max-width:640px){.card-preview{--preview-scale:.34;--preview-inverse:2.941;height:clamp(200px,60cqw,300px)}.bento-page{padding:12px}.bento{gap:12px}.span-8,.span-6,.span-4,.span-3,.span-12,.col-3{grid-column:span 12}.row-2{grid-row:span 1}.hero-card{min-height:280px;padding:28px}.hero-card h1,.hero h1{font-size:32px}.gallery-masonry{grid-template-rows:120px 120px;grid-template-columns:1fr 1fr}.gallery-masonry .tall{grid-row:span 1}.projects-grid,.gallery-pairs,.now-grid,.tl-item,.testimonial-split,.blog-entry{grid-template-columns:1fr}.about-text{font-size:17px}.gallery-pairs .wide{grid-column:span 1}.dashboard{gap:12px;padding:16px}.topbar{padding:12px 16px}.topbar nav{display:none}.identity,.stats-row{flex-direction:column}.stat-cell+.stat-cell{border-left:0;border-top:1px solid var(--border-cool)}}@media (max-width:480px){.nav-links{display:none}.bleed .pull-quote{font-size:22px}.gallery-bleed .g-main{height:240px}.gallery-bleed .g-strip{flex-wrap:wrap}.gallery-bleed .g-sm{flex:1 0 80px;height:60px}.t-pull blockquote{font-size:18px}.blog-excerpt h3{font-size:20px}}
