@charset "UTF-8";:root{color-scheme:light dark;--bg: oklch(.18 .01 260);--bg-2: oklch(.22 .012 260);--bg-3: oklch(.26 .014 260);--fg: oklch(.96 .008 80);--fg-dim: oklch(.78 .01 80);--fg-mute: oklch(.58 .012 80);--line: oklch(.32 .012 260);--line-soft: oklch(.26 .01 260);--accent: oklch(.72 .17 28);--accent-ink: oklch(.18 .01 260);--accent-soft: oklch(.72 .17 28 / .14);--ok: oklch(.78 .14 150);--warn: oklch(.82 .15 80);--err: oklch(.7 .18 28);--font-display: "Instrument Serif", "Times New Roman", serif;--font-ui: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, monospace;--font-ar: "Tajawal", "Inter", system-ui, sans-serif;--font-ar-display: "Amiri", "Instrument Serif", serif;--radius: 14px;--radius-sm: 8px;--radius-lg: 22px;--shadow-1: 0 1px 0 oklch(1 0 0 / .04), 0 8px 24px -16px oklch(0 0 0 / .5);--shadow-2: 0 30px 80px -40px oklch(0 0 0 / .7), 0 2px 8px -4px oklch(0 0 0 / .4);--section-y: 120px;--gap-card: 16px;--hero-y: 140px}@media(prefers-color-scheme:light){:root:not([data-theme=dark]){--bg: oklch(.985 .004 80);--bg-2: oklch(.96 .006 80);--bg-3: oklch(.93 .008 80);--fg: oklch(.2 .012 260);--fg-dim: oklch(.38 .012 260);--fg-mute: oklch(.54 .012 260);--line: oklch(.88 .008 80);--line-soft: oklch(.92 .008 80);--accent-ink: oklch(.985 .004 80);--shadow-1: 0 1px 0 oklch(0 0 0 / .03), 0 8px 24px -16px oklch(0 0 0 / .18);--shadow-2: 0 24px 60px -30px oklch(0 0 0 / .25), 0 1px 4px -2px oklch(0 0 0 / .1)}}:root[data-theme=light]{--bg: oklch(.985 .004 80);--bg-2: oklch(.96 .006 80);--bg-3: oklch(.93 .008 80);--fg: oklch(.2 .012 260);--fg-dim: oklch(.38 .012 260);--fg-mute: oklch(.54 .012 260);--line: oklch(.88 .008 80);--line-soft: oklch(.92 .008 80);--accent-ink: oklch(.985 .004 80);--shadow-1: 0 1px 0 oklch(0 0 0 / .03), 0 8px 24px -16px oklch(0 0 0 / .18);--shadow-2: 0 24px 60px -30px oklch(0 0 0 / .25), 0 1px 4px -2px oklch(0 0 0 / .1)}:root[data-theme=dark]{--bg: oklch(.18 .01 260);--bg-2: oklch(.22 .012 260);--bg-3: oklch(.26 .014 260);--fg: oklch(.96 .008 80);--fg-dim: oklch(.78 .01 80);--fg-mute: oklch(.58 .012 80);--line: oklch(.32 .012 260);--line-soft: oklch(.26 .01 260);--accent-ink: oklch(.18 .01 260);--shadow-1: 0 1px 0 oklch(1 0 0 / .04), 0 8px 24px -16px oklch(0 0 0 / .5);--shadow-2: 0 30px 80px -40px oklch(0 0 0 / .7), 0 2px 8px -4px oklch(0 0 0 / .4)}:root[data-density=compact]{--section-y: 80px;--gap-card: 12px;--hero-y: 100px}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;scroll-padding-top:100px;overflow-x:hidden}body{background:var(--bg);color:var(--fg);font-family:var(--font-ui);font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased;font-feature-settings:"ss01","cv11";transition:background .22s ease,color .22s ease}body[data-lang=ar]{font-family:var(--font-ar)}body[data-lang=ar] .h-display,body[data-lang=ar] .section-title,body[data-lang=ar] .hero h1,body[data-lang=ar] .footer-brand h3{font-family:var(--font-ar-display);letter-spacing:0}a{color:inherit;text-decoration:none}button{font-family:inherit;border:none;background:none;cursor:pointer;color:inherit}img,svg{display:block;max-width:100%}ul,ol{list-style:none}.shell{max-width:1240px;margin:0 auto;padding:0 32px}.shell-narrow{max-width:880px;margin:0 auto;padding:0 32px}@media(max-width:640px){.shell,.shell-narrow{padding:0 20px}}.section{padding:var(--section-y) 0;position:relative}.section+.section{border-top:1px solid var(--line)}@media(max-width:720px){.section{padding:calc(var(--section-y) * .7) 0}}.eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-mute);display:inline-flex;align-items:center;gap:10px}.eyebrow:before{content:"";width:22px;height:1px;background:var(--accent)}[dir=rtl] .eyebrow:before{content:none}[dir=rtl] .eyebrow:after{content:"";width:22px;height:1px;background:var(--accent)}.h-display{font-family:var(--font-display);font-weight:400;letter-spacing:-.02em;line-height:1.02}.section-title{font-family:var(--font-display);font-size:clamp(42px,5.5vw,72px);line-height:1.05;letter-spacing:-.02em;margin-top:18px;max-width:16ch}.section-lede{margin-top:20px;color:var(--fg-dim);max-width:56ch;font-size:17px}.divider{height:1px;background:var(--line);margin:0}.nav{position:fixed;top:0;left:0;right:0;z-index:50;transition:background .22s ease,border-color .22s ease;border-bottom:1px solid transparent}.nav[data-stuck=true]{background:color-mix(in oklch,var(--bg) 80%,transparent);backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);border-bottom-color:var(--line)}.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px;gap:16px}.logo{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-display);font-size:22px;letter-spacing:-.01em;flex-shrink:0}.logo-mark{width:32px;height:32px;border-radius:8px;background:var(--accent);color:var(--accent-ink);display:grid;place-items:center;font-family:var(--font-mono);font-weight:600;font-size:13px}.logo .dot{color:var(--accent);font-style:italic}.nav-links{display:flex;align-items:center;gap:2px;background:color-mix(in oklch,var(--bg-2) 70%,transparent);border:1px solid var(--line);padding:5px;border-radius:999px}.nav-link{font-size:13px;padding:8px 14px;border-radius:999px;color:var(--fg-dim);transition:color .18s ease,background .18s ease;white-space:nowrap}.nav-link:hover{color:var(--fg)}.nav-link[data-active=true]{color:var(--fg);background:var(--bg-3)}.nav-tools{display:flex;align-items:center;gap:8px;flex-shrink:0}.icon-btn{width:38px;height:38px;border:1px solid var(--line);border-radius:10px;display:inline-grid;place-items:center;color:var(--fg-dim);transition:all .18s ease;font-family:var(--font-mono);font-size:12px;font-weight:500}.icon-btn:hover{color:var(--fg);border-color:var(--fg-dim)}.icon-btn[data-active=true]{color:var(--accent);border-color:var(--accent)}.nav-cta{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:999px;background:var(--accent);color:var(--accent-ink);font-size:13px;font-weight:500;transition:transform .18s ease,box-shadow .18s ease}.nav-cta:hover{transform:translateY(-1px);box-shadow:0 10px 30px -10px var(--accent)}.nav-cta .pulse-dot{width:6px;height:6px;border-radius:50%;background:var(--accent-ink);animation:pulse-soft 2.4s ease-in-out infinite}@keyframes pulse-soft{0%,to{opacity:.7}50%{opacity:1}}.nav-burger{display:none;width:38px;height:38px;border:1px solid var(--line);border-radius:10px;place-items:center}.nav-burger span{width:16px;height:1.5px;background:var(--fg);position:relative;display:block}.nav-burger span:before,.nav-burger span:after{content:"";position:absolute;left:0;width:16px;height:1.5px;background:var(--fg)}.nav-burger span:before{top:-5px}.nav-burger span:after{top:5px}@media(max-width:880px){.nav-links{display:none}.nav-burger{display:grid}.nav-links[data-open=true]{display:flex;flex-direction:column;align-items:stretch;position:absolute;top:80px;left:16px;right:16px;border-radius:16px;padding:10px;background:var(--bg-2);border:1px solid var(--line);box-shadow:var(--shadow-2)}.nav-links[data-open=true] .nav-link{padding:14px 18px;border-radius:10px}}@media(max-width:600px){.nav-cta{display:none}}.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 22px;border-radius:999px;font-size:14px;font-weight:500;transition:transform .18s ease,background .18s ease,color .18s ease,border-color .18s ease;border:1px solid transparent}.btn-primary{background:var(--accent);color:var(--accent-ink)}.btn-primary:hover{transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--fg);border-color:var(--line)}.btn-ghost:hover{border-color:var(--fg)}.btn .arrow{width:14px;height:14px;transition:transform .22s ease}.btn:hover .arrow{transform:translate(2px,-2px)}[dir=rtl] .btn:hover .arrow{transform:translate(-2px,-2px)}.link-arrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:12px;color:var(--fg-dim);letter-spacing:.04em;text-transform:uppercase;transition:color .18s ease}.link-arrow:hover{color:var(--accent)}.link-arrow .arr{width:12px;height:12px;transition:transform .22s ease}.link-arrow:hover .arr{transform:translate(3px)}[dir=rtl] .link-arrow:hover .arr{transform:translate(-3px) scaleX(-1)}[dir=rtl] .link-arrow .arr{transform:scaleX(-1)}.hero{padding:var(--hero-y) 0 var(--section-y);position:relative}.hero-grid{display:grid;grid-template-columns:1.35fr 1fr;gap:60px;align-items:end}.hero-meta{display:flex;flex-wrap:wrap;gap:18px;font-family:var(--font-mono);font-size:11.5px;color:var(--fg-mute);letter-spacing:.06em;text-transform:uppercase;margin-bottom:36px}.hero-meta span{display:inline-flex;align-items:center;gap:8px}.hero-meta .pulse{width:8px;height:8px;border-radius:50%;background:var(--ok);box-shadow:0 0 color-mix(in oklch,var(--ok) 50%,transparent);animation:pulse 2s infinite}@keyframes pulse{0%{box-shadow:0 0 color-mix(in oklch,var(--ok) 60%,transparent)}70%{box-shadow:0 0 0 10px transparent}to{box-shadow:0 0 0 0 transparent}}.hero h1{font-family:var(--font-display);font-size:clamp(56px,9vw,132px);line-height:.96;letter-spacing:-.03em}.hero h1 .accent{color:var(--accent);font-style:italic}.hero h1 .nw{white-space:nowrap}.hero-bio{font-size:17px;color:var(--fg-dim);max-width:44ch;margin-top:32px}.hero-actions{display:flex;gap:12px;margin-top:36px;flex-wrap:wrap}.hero-card{border:1px solid var(--line);border-radius:18px;padding:22px;background:linear-gradient(180deg,var(--bg-2),var(--bg));position:relative;overflow:hidden}.hero-portrait{aspect-ratio:4/5;border-radius:12px;background:repeating-linear-gradient(45deg,var(--bg-3) 0 10px,var(--bg-2) 10px 20px);position:relative;overflow:hidden;margin-bottom:18px}.hero-portrait img{width:100%;height:100%;object-fit:cover;object-position:top center;border-radius:12px}.hero-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px}.hero-stat{padding:14px;border:1px solid var(--line);border-radius:10px}.hero-stat .n{font-family:var(--font-display);font-size:clamp(22px,5.5vw,34px);line-height:1}.hero-stat .l{font-family:var(--font-mono);font-size:10px;color:var(--fg-mute);text-transform:uppercase;letter-spacing:.1em;margin-top:6px}@media(max-width:960px){.hero-grid{grid-template-columns:1fr;gap:48px}.hero{padding:120px 0 80px}.hero[data-variant=terminal] .hero-grid{grid-template-columns:1fr}}.hero[data-variant=centered] .hero-grid{display:block;text-align:center}.hero[data-variant=centered] .hero-bio{margin-left:auto;margin-right:auto}.hero[data-variant=centered] .hero-actions{justify-content:center}.hero[data-variant=centered] .hero-card{max-width:720px;margin:60px auto 0}.hero[data-variant=centered] h1{font-size:clamp(48px,11vw,168px)}.hero[data-variant=centered] .hero-meta,.hero[data-variant=centered] .eyebrow{justify-content:center}.hero[data-variant=terminal] .hero-grid{grid-template-columns:1fr 1.1fr}.hero[data-variant=terminal] h1{font-size:clamp(44px,6.5vw,92px)}.hero[data-variant=terminal] .hero-card{padding:0;background:var(--bg-2)}.hero[data-variant=terminal] .terminal{font-family:var(--font-mono);font-size:13px;line-height:1.7;color:var(--fg-dim);padding:22px}.hero[data-variant=terminal] .terminal-bar{display:flex;align-items:center;gap:6px;padding:12px 16px;border-bottom:1px solid var(--line)}.hero[data-variant=terminal] .terminal-bar .dot{width:10px;height:10px;border-radius:50%}.hero[data-variant=terminal] .terminal-bar .dot:nth-child(1){background:#fa695c}.hero[data-variant=terminal] .terminal-bar .dot:nth-child(2){background:#f7b83d}.hero[data-variant=terminal] .terminal-bar .dot:nth-child(3){background:#6fd087}.hero[data-variant=terminal] .terminal-bar .title{margin-left:auto;margin-right:auto;font-family:var(--font-mono);font-size:11px;color:var(--fg-mute)}.hero[data-variant=terminal] .prompt{color:var(--accent)}.hero[data-variant=terminal] .out{color:var(--fg)}.hero[data-variant=terminal] .cmt{color:var(--fg-mute)}.marquee{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:22px 0;margin-top:40px;-webkit-mask-image:linear-gradient(90deg,transparent,black 10%,black 90%,transparent);mask-image:linear-gradient(90deg,transparent,black 10%,black 90%,transparent)}.marquee-track{display:flex;gap:48px;white-space:nowrap;animation:scroll 40s linear infinite;font-family:var(--font-mono);font-size:13px;color:var(--fg-mute);letter-spacing:.05em}.marquee-track span{display:inline-flex;align-items:center;gap:16px}.marquee-track .sep{color:var(--accent)}@keyframes scroll{to{transform:translate(-50%)}}[dir=rtl] .marquee-track{animation-direction:reverse}.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap-card);margin-top:60px}@media(max-width:900px){.services-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.services-grid{grid-template-columns:1fr}}.service{border:1px solid var(--line);border-radius:var(--radius);padding:28px;background:var(--bg-2);transition:border-color .22s ease,transform .22s ease,background .22s ease;position:relative;overflow:hidden;min-height:240px;display:flex;flex-direction:column;justify-content:space-between}.service:hover{border-color:var(--accent);transform:translateY(-2px)}.service .num{font-family:var(--font-mono);font-size:11px;color:var(--fg-mute);letter-spacing:.1em}.service .icon{width:42px;height:42px;border:1px solid var(--line);border-radius:10px;display:grid;place-items:center;color:var(--accent);margin-bottom:18px;transition:border-color .22s ease,background .22s ease}.service:hover .icon{border-color:var(--accent);background:var(--accent-soft)}.service h3{font-family:var(--font-display);font-size:clamp(20px,4vw,28px);font-weight:400;letter-spacing:-.01em;margin-bottom:10px}.service p{color:var(--fg-dim);font-size:14.5px}.service .tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:18px}.service .tag{font-family:var(--font-mono);font-size:10.5px;padding:4px 8px;border-radius:4px;background:var(--bg-3);color:var(--fg-dim);letter-spacing:.04em}.crumbs{display:flex;flex-wrap:wrap;gap:8px;align-items:center;font-family:var(--font-mono);font-size:11px;color:var(--fg-mute);letter-spacing:.06em;text-transform:uppercase;margin-bottom:24px}.crumbs a{color:var(--fg-dim);transition:color .18s}.crumbs a:hover,.crumbs .sep{color:var(--accent)}.page-header{padding:160px 0 60px;position:relative}.page-header h1{font-family:var(--font-display);font-size:clamp(54px,8.5vw,120px);line-height:.96;letter-spacing:-.03em;max-width:16ch}.page-header h1 .accent{color:var(--accent);font-style:italic}.page-header .lede{margin-top:26px;max-width:60ch;color:var(--fg-dim);font-size:18px}.page-header .meta-row{display:flex;flex-wrap:wrap;gap:22px;margin-top:36px;padding-top:28px;border-top:1px solid var(--line);font-family:var(--font-mono);font-size:11.5px;color:var(--fg-mute);letter-spacing:.06em;text-transform:uppercase}.page-header .meta-row span{display:inline-flex;align-items:center;gap:8px}.page-header .meta-row strong{color:var(--fg);font-weight:500}.row-list{margin-top:40px}.row{display:grid;grid-template-columns:140px 1fr auto;gap:36px;align-items:start;padding:32px 0;border-top:1px solid var(--line);transition:padding .22s ease;position:relative}.row:last-child{border-bottom:1px solid var(--line)}.row:hover{padding-left:12px}[dir=rtl] .row:hover{padding-left:0;padding-right:12px}.row .date{font-family:var(--font-mono);font-size:11.5px;color:var(--fg-mute);letter-spacing:.08em;text-transform:uppercase;padding-top:4px}.row .body h3{font-family:var(--font-display);font-size:clamp(20px,4.5vw,30px);font-weight:400;letter-spacing:-.01em;line-height:1.15}.row .body .org{display:inline-block;font-size:14px;color:var(--fg-dim);margin-top:8px;padding:3px 10px;border-radius:999px;background:var(--bg-2);border:1px solid var(--line)}.row .body p{color:var(--fg-dim);font-size:15px;margin-top:16px;max-width:66ch}.row .body .row-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:16px}.row .body .row-tags span{font-family:var(--font-mono);font-size:10.5px;padding:4px 8px;border-radius:4px;background:var(--bg-3);color:var(--fg-dim);letter-spacing:.04em}.row .action{align-self:center}.row a.row-more{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11.5px;color:var(--fg-mute);letter-spacing:.06em;text-transform:uppercase;transition:color .18s}.row:hover a.row-more{color:var(--accent)}.row .ord{font-family:var(--font-mono);font-size:11px;color:var(--fg-mute);margin-bottom:6px;letter-spacing:.08em}@media(max-width:760px){.row{grid-template-columns:1fr;gap:12px}.row .action{justify-self:start}}.works{display:grid;grid-template-columns:repeat(6,1fr);gap:var(--gap-card);margin-top:48px}.work{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--bg-2);position:relative;cursor:pointer;transition:transform .4s cubic-bezier(.2,.8,.2,1),opacity .3s ease;display:flex;flex-direction:column}.work.w-lg{grid-column:span 4}.work.w-md{grid-column:span 3}.work.w-sm{grid-column:span 2}@media(max-width:900px){.works{grid-template-columns:repeat(2,1fr)}.work.w-lg,.work.w-md,.work.w-sm{grid-column:span 2}}@media(max-width:480px){.works{grid-template-columns:1fr}.work.w-lg,.work.w-md,.work.w-sm{grid-column:span 1}}.work.hidden{display:none}.work-media{aspect-ratio:16/10;position:relative;background:repeating-linear-gradient(135deg,var(--bg-3) 0 12px,var(--bg-2) 12px 24px);overflow:hidden}.work.w-sm .work-media{aspect-ratio:4/3}.work-overlay{position:absolute;inset:0;background:color-mix(in oklch,var(--bg) 75%,transparent);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .26s ease}.work:hover .work-overlay{opacity:1}.work-open{width:56px;height:56px;border-radius:50%;background:var(--accent);color:var(--accent-ink);display:grid;place-items:center;transform:scale(.7);transition:transform .28s cubic-bezier(.2,.8,.2,1)}.work:hover .work-open{transform:scale(1)}.work-info{padding:18px 20px 20px;display:flex;justify-content:space-between;align-items:start;gap:16px}.work-info h4{font-family:var(--font-display);font-size:22px;font-weight:400;letter-spacing:-.01em}.work-info .cat{font-family:var(--font-mono);font-size:10.5px;color:var(--fg-mute);text-transform:uppercase;letter-spacing:.1em;margin-top:6px}.work-info .year{font-family:var(--font-mono);font-size:11px;color:var(--fg-mute);white-space:nowrap;padding-top:4px}.filters{display:flex;gap:6px;flex-wrap:wrap;margin-top:24px}.filter{font-family:var(--font-mono);font-size:11.5px;padding:10px 14px;border-radius:999px;border:1px solid var(--line);color:var(--fg-dim);letter-spacing:.05em;transition:all .18s ease}.filter[data-active=true]{background:var(--fg);color:var(--bg);border-color:var(--fg)}.filter:hover:not([data-active=true]){color:var(--fg);border-color:var(--fg)}.filter .count{color:var(--fg-mute);margin-left:6px}.filter[data-active=true] .count{color:color-mix(in oklch,var(--bg) 60%,var(--fg))}.works-head{display:flex;justify-content:space-between;align-items:end;gap:30px;flex-wrap:wrap}.proj-hero{padding:140px 0 60px}.proj-hero h1{font-family:var(--font-display);font-size:clamp(54px,8.5vw,120px);line-height:.96;letter-spacing:-.03em;max-width:16ch}.proj-hero .lede{margin-top:26px;max-width:60ch;color:var(--fg-dim);font-size:18px}.proj-body-section{padding-bottom:var(--section-y)}.pn-end{text-align:end}.post-header{padding:140px 0 60px}.post-header .post-tag{font-family:var(--font-mono);font-size:11px;color:var(--accent);text-transform:uppercase;letter-spacing:.1em}.post-header h1{font-family:var(--font-display);font-size:clamp(40px,6vw,80px);line-height:1;letter-spacing:-.03em;margin-top:16px;max-width:20ch}.post-header .post-meta-row{margin-top:20px;font-family:var(--font-mono);font-size:12px;color:var(--fg-mute);letter-spacing:.06em;display:flex;flex-wrap:wrap;gap:20px}.post-article{max-width:70ch;margin:0 auto}.post-lede{font-size:18px;color:var(--fg-dim);line-height:1.7;margin-bottom:40px;border-left:3px solid var(--accent);padding-left:20px}[dir=rtl] .post-lede{border-left:none;border-right:3px solid var(--accent);padding-left:0;padding-right:20px}.post-foot-link{margin-top:60px;padding-top:40px;border-top:1px solid var(--line)}.post-foot-link a{font-family:var(--font-mono);font-size:12px;color:var(--fg-mute);letter-spacing:.06em;text-transform:uppercase;transition:color .18s}.post-foot-link a:hover{color:var(--accent)}@media(max-width:720px){.post-header{padding:100px 0 40px}}@media(max-width:640px){.proj-body-section{padding-bottom:60px}.proj-hero{padding:100px 0 40px}}.proj-cover{margin-top:40px;aspect-ratio:16/9;border-radius:var(--radius);background:repeating-linear-gradient(135deg,var(--bg-3) 0 14px,var(--bg-2) 14px 28px);border:1px solid var(--line);position:relative;overflow:hidden}.proj-meta{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:40px;padding:24px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}@media(max-width:760px){.proj-meta{grid-template-columns:repeat(2,1fr)}}.proj-meta .pm-label{font-family:var(--font-mono);font-size:10.5px;color:var(--fg-mute);text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px}.proj-meta .pm-val{font-family:var(--font-display);font-size:20px}.proj-meta .pm-val a{color:var(--fg);border-bottom:1px solid var(--line);transition:border-color .18s,color .18s}.proj-meta .pm-val a:hover{color:var(--accent);border-color:var(--accent)}.proj-body{display:grid;grid-template-columns:220px 1fr;gap:60px;margin-top:60px}@media(max-width:900px){.proj-body{grid-template-columns:1fr;gap:32px}}.proj-toc{position:sticky;top:100px;font-family:var(--font-mono);font-size:12px;align-self:start}.proj-toc h5{font-family:var(--font-mono);font-size:11px;color:var(--fg-mute);text-transform:uppercase;letter-spacing:.12em;margin-bottom:16px;font-weight:500}.proj-toc ol{display:flex;flex-direction:column;gap:4px;counter-reset:toc}.proj-toc a{display:flex;gap:10px;padding:8px 0;color:var(--fg-dim);border-top:1px dashed var(--line-soft);transition:color .18s}.proj-toc a:hover{color:var(--accent)}.proj-toc a:before{counter-increment:toc;content:counter(toc,decimal-leading-zero) " /";color:var(--fg-mute)}.proj-prose{max-width:70ch}.proj-prose h2{font-family:var(--font-display);font-weight:400;font-size:38px;letter-spacing:-.02em;line-height:1.1;margin-top:48px;margin-bottom:16px}.proj-prose h2:first-child{margin-top:0}.proj-prose p{color:var(--fg-dim);font-size:16.5px;margin-bottom:16px;line-height:1.7}.proj-prose ul{margin:12px 0 20px 22px}.proj-prose ul li{color:var(--fg-dim);font-size:16px;margin-bottom:8px;list-style:none;position:relative}.proj-prose ul li:before{content:"\2014";position:absolute;left:-22px;color:var(--accent)}[dir=rtl] .proj-prose ul{margin:12px 22px 20px 0}[dir=rtl] .proj-prose ul li:before{left:auto;right:-22px}.proj-prose blockquote{border-left:2px solid var(--accent);padding:6px 0 6px 20px;margin:24px 0;font-family:var(--font-display);font-size:22px;color:var(--fg);line-height:1.4}[dir=rtl] .proj-prose blockquote{border-left:none;border-right:2px solid var(--accent);padding:6px 20px 6px 0}.proj-prose code{font-family:var(--font-mono);font-size:13px;background:var(--bg-2);padding:2px 6px;border-radius:4px;border:1px solid var(--line);color:var(--accent)}.proj-prose pre{background:var(--bg-2);border:1px solid var(--line);padding:20px;border-radius:12px;margin:20px 0;overflow-x:auto;font-family:var(--font-mono);font-size:13px;line-height:1.7;color:var(--fg-dim)}.proj-nav{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap-card);margin-top:80px;padding-top:40px;border-top:1px solid var(--line)}@media(max-width:700px){.proj-nav{grid-template-columns:1fr}}.proj-nav a{display:flex;flex-direction:column;gap:8px;padding:24px;border:1px solid var(--line);border-radius:var(--radius);background:var(--bg-2);transition:all .18s}.proj-nav a:hover{border-color:var(--accent);transform:translateY(-2px)}.proj-nav .pn-label{font-family:var(--font-mono);font-size:10.5px;color:var(--fg-mute);text-transform:uppercase;letter-spacing:.1em}.proj-nav .pn-title{font-family:var(--font-display);font-size:24px}.about-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:60px;margin-top:40px}@media(max-width:900px){.about-grid{grid-template-columns:1fr;gap:40px}}.about-portrait{position:sticky;top:100px;align-self:start}.about-portrait .pframe{aspect-ratio:4/5;border-radius:var(--radius);background:repeating-linear-gradient(45deg,var(--bg-3) 0 12px,var(--bg-2) 12px 24px);border:1px solid var(--line);position:relative;overflow:hidden}.about-portrait .pframe img{width:100%;height:100%;object-fit:cover;object-position:top center}.about-portrait .pmeta{margin-top:20px;display:flex;flex-direction:column;gap:14px;padding:20px;border:1px solid var(--line);border-radius:var(--radius);background:var(--bg-2)}.about-portrait .pmeta-row{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--font-mono);font-size:12px;padding-bottom:12px;border-bottom:1px dashed var(--line)}.about-portrait .pmeta-row:last-child{padding-bottom:0;border-bottom:none}.about-portrait .pmeta-row .k{color:var(--fg-mute);text-transform:uppercase;letter-spacing:.08em;font-size:10.5px}.about-portrait .pmeta-row .v{color:var(--fg)}.about-body h2{font-family:var(--font-display);font-weight:400;font-size:36px;letter-spacing:-.01em;line-height:1.15;margin-top:48px;margin-bottom:16px}.about-body h2:first-child{margin-top:0}.about-body p{color:var(--fg-dim);font-size:17px;line-height:1.7;margin-bottom:16px;max-width:64ch}.about-body p .em{color:var(--fg);font-style:italic}.about-body .stack{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:12px}@media(max-width:600px){.about-body .stack{grid-template-columns:repeat(2,1fr)}}.about-body .stack span{font-family:var(--font-mono);font-size:12px;padding:10px 12px;border:1px solid var(--line);border-radius:8px;color:var(--fg-dim)}.about-body .quotebox{margin:32px 0;padding:28px;border:1px solid var(--line);border-radius:var(--radius);background:var(--bg-2)}.about-body .quotebox blockquote{font-family:var(--font-display);font-size:24px;line-height:1.4;color:var(--fg)}.about-body .quotebox blockquote:before{content:"\201c";color:var(--accent);margin-right:4px}.cv{background:var(--bg)}.cv-paper{max-width:900px;margin:100px auto 60px;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);padding:64px;box-shadow:var(--shadow-2)}@media(max-width:720px){.cv-paper{padding:32px;margin:90px 16px 40px}}.cv-paper header{padding-bottom:32px;border-bottom:1px solid var(--line);margin-bottom:32px;display:flex;justify-content:space-between;align-items:end;gap:24px;flex-wrap:wrap}.cv-paper header h1{font-family:var(--font-display);font-size:clamp(28px,6vw,48px);letter-spacing:-.02em;line-height:1;font-weight:400}.cv-paper header h1 .accent{color:var(--accent);font-style:italic}.cv-paper header .sub{font-family:var(--font-mono);font-size:11.5px;color:var(--fg-mute);letter-spacing:.1em;text-transform:uppercase;margin-top:8px}.cv-paper header .contact-line{font-family:var(--font-mono);font-size:12px;color:var(--fg-dim);line-height:1.8;text-align:right}.cv-paper header .contact-line a{color:var(--fg-dim);border-bottom:1px solid var(--line)}.cv-paper header .contact-line a:hover{color:var(--accent)}.cv-section{margin-bottom:36px}.cv-section h2{font-family:var(--font-mono);font-size:11px;color:var(--fg-mute);text-transform:uppercase;letter-spacing:.14em;margin-bottom:18px;padding-bottom:8px;border-bottom:1px solid var(--line);font-weight:500}.cv-item{padding:12px 0 16px;border-bottom:1px dashed var(--line-soft)}.cv-item:last-child{border-bottom:none}.cv-item .top{display:flex;justify-content:space-between;align-items:baseline;gap:16px;flex-wrap:wrap}.cv-item .top h3{font-family:var(--font-display);font-size:22px;font-weight:400;letter-spacing:-.01em}.cv-item .top .when{font-family:var(--font-mono);font-size:11px;color:var(--fg-mute);letter-spacing:.05em}.cv-item .org{color:var(--fg-dim);font-size:14px;margin-top:4px}.cv-item ul{margin-top:10px}.cv-item li{font-size:14.5px;color:var(--fg-dim);padding-left:18px;position:relative;margin-bottom:4px;line-height:1.6;list-style:none}.cv-item li:before{content:"\2014";color:var(--accent);position:absolute;left:0}[dir=rtl] .cv-item li{padding-left:0;padding-right:18px}[dir=rtl] .cv-item li:before{left:auto;right:0}.cv-skills-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}@media(max-width:600px){.cv-skills-grid{grid-template-columns:repeat(2,1fr)}}.cv-skills-grid span{font-family:var(--font-mono);font-size:11.5px;padding:8px 10px;border:1px solid var(--line);border-radius:6px;color:var(--fg-dim)}.contact-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:60px;margin-top:60px}@media(max-width:820px){.contact-grid{grid-template-columns:1fr;gap:40px}}.contact-info{display:flex;flex-direction:column;gap:24px}.contact-item{display:flex;gap:16px;align-items:start;padding:20px 0;border-top:1px solid var(--line)}.contact-item:last-child{border-bottom:1px solid var(--line)}.contact-item .ci-icon{width:40px;height:40px;border:1px solid var(--line);border-radius:10px;display:grid;place-items:center;color:var(--accent);flex-shrink:0}.contact-item .ci-label{font-family:var(--font-mono);font-size:10.5px;color:var(--fg-mute);text-transform:uppercase;letter-spacing:.1em;margin-bottom:4px}.contact-item .ci-val{font-family:var(--font-display);font-size:20px;letter-spacing:-.01em}.contact-item a.ci-val:hover{color:var(--accent)}.form{display:flex;flex-direction:column;gap:16px;padding:32px;border:1px solid var(--line);border-radius:18px;background:var(--bg-2)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media(max-width:520px){.form-row{grid-template-columns:1fr}}.field{position:relative}.field label{font-family:var(--font-mono);font-size:10.5px;color:var(--fg-mute);text-transform:uppercase;letter-spacing:.1em;display:block;margin-bottom:6px}.field input,.field textarea,.field select{width:100%;background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:14px;color:var(--fg);font-family:inherit;font-size:14.5px;transition:border-color .18s ease}.field textarea{resize:vertical;min-height:140px}.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--accent)}.field .err{font-family:var(--font-mono);font-size:11px;color:var(--err);margin-top:6px;opacity:0;transition:opacity .18s ease}.field[data-invalid=true] input,.field[data-invalid=true] textarea{border-color:var(--err)}.field[data-invalid=true] .err{opacity:1}.form-submit{display:flex;justify-content:space-between;align-items:center;margin-top:8px;gap:16px;flex-wrap:wrap}.form-note{font-family:var(--font-mono);font-size:11px;color:var(--fg-mute);letter-spacing:.04em}.form-success{padding:20px;border-radius:12px;background:color-mix(in oklch,var(--ok) 20%,var(--bg-2));border:1px solid color-mix(in oklch,var(--ok) 40%,var(--line));color:var(--fg);font-size:14px;display:none}.form-success.visible{display:block}.posts{display:grid;gap:var(--gap-card);margin-top:40px}.post-card{display:grid;grid-template-columns:220px 1fr auto;gap:32px;align-items:start;padding:28px 0;border-top:1px solid var(--line);transition:padding .22s ease}.post-card:last-child{border-bottom:1px solid var(--line)}.post-card:hover{padding-left:12px}[dir=rtl] .post-card:hover{padding-left:0;padding-right:12px}.post-card .post-thumb{aspect-ratio:4/3;border-radius:10px;background:repeating-linear-gradient(135deg,var(--bg-3) 0 10px,var(--bg-2) 10px 20px);border:1px solid var(--line)}.post-card .post-meta{font-family:var(--font-mono);font-size:11px;color:var(--fg-mute);letter-spacing:.08em;text-transform:uppercase}.post-card .post-title{font-family:var(--font-display);font-size:clamp(20px,4.5vw,30px);margin-top:10px;letter-spacing:-.01em;line-height:1.15}.post-card .post-excerpt{margin-top:10px;color:var(--fg-dim);font-size:15px;max-width:60ch}.post-card .post-tags{margin-top:14px;display:flex;flex-wrap:wrap;gap:6px}.post-card .post-tags span{font-family:var(--font-mono);font-size:10.5px;padding:4px 8px;border-radius:4px;background:var(--bg-3);color:var(--fg-dim)}.post-card .post-read{align-self:center;font-family:var(--font-mono);font-size:12px;color:var(--fg-mute);letter-spacing:.06em;text-transform:uppercase;white-space:nowrap}.post-card:hover .post-read{color:var(--accent)}@media(max-width:760px){.post-card{grid-template-columns:1fr}.post-card .post-thumb{aspect-ratio:16/9}}.blog-post{max-width:720px;margin:140px auto 80px;padding:0 32px}.blog-post .post-head{padding-bottom:32px;border-bottom:1px solid var(--line);margin-bottom:32px}.blog-post .post-head .tag{font-family:var(--font-mono);font-size:11px;color:var(--accent);text-transform:uppercase;letter-spacing:.12em}.blog-post .post-head h1{font-family:var(--font-display);font-weight:400;font-size:clamp(40px,6vw,64px);line-height:1.05;letter-spacing:-.02em;margin-top:14px}.blog-post .post-head .meta{font-family:var(--font-mono);font-size:11.5px;color:var(--fg-mute);letter-spacing:.08em;text-transform:uppercase;margin-top:18px;display:flex;gap:20px;flex-wrap:wrap}.blog-post .post-body p{font-size:17.5px;color:var(--fg-dim);line-height:1.75;margin-bottom:18px}.blog-post .post-body h2{font-family:var(--font-display);font-weight:400;font-size:36px;letter-spacing:-.02em;line-height:1.15;margin-top:44px;margin-bottom:14px}.blog-post .post-body h3{font-family:var(--font-display);font-weight:400;font-size:26px;margin-top:32px;margin-bottom:12px;letter-spacing:-.01em}.blog-post .post-body code{font-family:var(--font-mono);font-size:13.5px;background:var(--bg-2);padding:2px 6px;border-radius:4px;border:1px solid var(--line);color:var(--accent)}.blog-post .post-body pre{background:var(--bg-2);border:1px solid var(--line);padding:20px;border-radius:12px;margin:20px 0;overflow-x:auto;font-family:var(--font-mono);font-size:13px;line-height:1.7;color:var(--fg-dim)}.blog-post .post-body blockquote{border-left:2px solid var(--accent);padding:8px 0 8px 22px;margin:28px 0;font-family:var(--font-display);font-size:24px;color:var(--fg);line-height:1.4}[dir=rtl] .blog-post .post-body blockquote{border-left:none;border-right:2px solid var(--accent);padding:8px 22px 8px 0}.blog-post .post-body ul{margin:12px 0 20px 22px}.blog-post .post-body ul li{list-style:none;position:relative;color:var(--fg-dim);font-size:17px;margin-bottom:10px;line-height:1.7}.blog-post .post-body ul li:before{content:"\2014";position:absolute;left:-22px;color:var(--accent)}.post-foot{margin-top:60px;padding-top:30px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.stat-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap-card);margin-top:60px}@media(max-width:760px){.stat-strip{grid-template-columns:repeat(2,1fr)}}.stat-card{padding:28px;border:1px solid var(--line);border-radius:var(--radius);background:var(--bg-2);transition:border-color .2s}.stat-card:hover{border-color:var(--accent)}.stat-card .n{font-family:var(--font-display);font-size:60px;line-height:1;letter-spacing:-.02em}.stat-card .n .accent{color:var(--accent);font-style:italic}.stat-card .l{font-family:var(--font-mono);font-size:11px;color:var(--fg-mute);text-transform:uppercase;letter-spacing:.1em;margin-top:12px}.stat-card .d{margin-top:14px;font-size:14px;color:var(--fg-dim)}.skills-layout{display:grid;grid-template-columns:1fr 1.4fr;gap:60px;margin-top:60px}@media(max-width:900px){.skills-layout{grid-template-columns:1fr;gap:40px}}.skills-col h3{font-family:var(--font-mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.12em;color:var(--fg-mute);margin-bottom:24px}.skill{margin-bottom:20px}.skill-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}.skill-name{font-family:var(--font-display);font-size:18px}.skill-level{font-family:var(--font-mono);font-size:11px;color:var(--fg-mute);letter-spacing:.08em}.skill-bar{height:3px;background:var(--bg-3);border-radius:2px;overflow:hidden;position:relative}.skill-bar span{display:block;height:100%;background:var(--accent);width:0;transition:width 1.2s cubic-bezier(.2,.8,.2,1)}.skill.in-view .skill-bar span{width:var(--w)}.knowledge-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}@media(max-width:600px){.knowledge-grid{grid-template-columns:repeat(2,1fr)}}.kchip{padding:12px 14px;border:1px solid var(--line);border-radius:10px;font-family:var(--font-mono);font-size:12px;color:var(--fg-dim);display:flex;justify-content:space-between;align-items:center;transition:all .18s ease}.kchip:hover{border-color:var(--accent);color:var(--fg)}.kchip .d{width:6px;height:6px;border-radius:50%;background:var(--fg-mute)}.feature-block{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:end;margin-bottom:32px}@media(max-width:760px){.feature-block{grid-template-columns:1fr;gap:24px}}.feature-block .lede{color:var(--fg-dim);font-size:17px;max-width:50ch}.footer{padding:80px 0 32px;border-top:1px solid var(--line)}.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:60px}@media(max-width:720px){.footer-grid{grid-template-columns:1fr 1fr}}@media(max-width:480px){.footer-grid{grid-template-columns:1fr}}.footer-brand h3{font-family:var(--font-display);font-size:clamp(28px,5.5vw,44px);line-height:1;font-weight:400;letter-spacing:-.02em;margin-bottom:12px}.footer-brand h3 .dot{color:var(--accent);font-style:italic}.footer-brand p{color:var(--fg-dim);font-size:14px;max-width:36ch}.footer-col h4{font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--fg-mute);margin-bottom:16px}.footer-col ul{display:flex;flex-direction:column;gap:10px}.footer-col a{color:var(--fg-dim);font-size:14px;transition:color .18s ease}.footer-col a:hover{color:var(--accent)}.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid var(--line);font-family:var(--font-mono);font-size:11px;color:var(--fg-mute);letter-spacing:.05em;flex-wrap:wrap;gap:12px}.footer-bottom .socials{display:flex;gap:6px}.footer-bottom .socials a{width:36px;height:36px;border-radius:8px;border:1px solid var(--line);display:grid;place-items:center;color:var(--fg-dim);transition:all .18s ease}.footer-bottom .socials a:hover{color:var(--accent-ink);background:var(--accent);border-color:var(--accent)}.tweaks{position:fixed;bottom:24px;right:24px;z-index:80;width:300px;background:var(--bg-2);border:1px solid var(--line);border-radius:16px;padding:20px;box-shadow:var(--shadow-2);display:none}.tweaks.open{display:block}[dir=rtl] .tweaks{right:auto;left:24px}@media(max-width:480px){.tweaks,[dir=rtl] .tweaks{left:16px;right:16px;bottom:16px}.tweaks-toggle{right:16px;bottom:16px}[dir=rtl] .tweaks-toggle{left:16px;right:auto;bottom:16px}}.tweaks-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.tweaks-header h5{font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--fg-mute)}.tweaks-header button{font-family:var(--font-mono);font-size:16px;color:var(--fg-mute)}.tweaks-header button:hover{color:var(--fg)}.tweaks-row{margin-bottom:16px}.tweaks-row:last-child{margin-bottom:0}.tweaks label{font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-mute);margin-bottom:8px;display:block}.swatches{display:flex;gap:8px;flex-wrap:wrap}.swatch{width:28px;height:28px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .18s ease}.swatch.active{border-color:var(--fg)}.swatch:hover{transform:scale(1.1)}.seg{display:flex;gap:3px;background:var(--bg-3);padding:3px;border-radius:8px}.seg button{flex:1;padding:8px;font-size:11.5px;border-radius:6px;color:var(--fg-dim);font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase}.seg button.active{background:var(--bg);color:var(--fg)}.tweaks-toggle{position:fixed;bottom:24px;right:24px;z-index:81;width:44px;height:44px;border-radius:12px;border:1px solid var(--line);background:var(--bg-2);display:grid;place-items:center;color:var(--fg-dim);box-shadow:var(--shadow-1);transition:all .18s ease}.tweaks-toggle:hover{color:var(--accent);border-color:var(--accent)}[dir=rtl] .tweaks-toggle{right:auto;left:24px}.fade{opacity:0;transform:translateY(24px);transition:opacity .8s ease,transform .8s cubic-bezier(.2,.8,.2,1)}.fade.in{opacity:1;transform:none}@media print{.nav,.footer,.tweaks,.tweaks-toggle{display:none!important}.cv-paper{box-shadow:none;border:none;margin:0;padding:0;max-width:100%}body{background:#fff!important;color:#000!important}}
