CloudFront
tcp/80
Open service 18.239.36.85:80 · dan.vg
2026-01-09 12:13
HTTP/1.1 200 OK
Server: CloudFront
Content-Type: text/html
Content-Length: 20271
Connection: close
Content-Md5: GQUB2MpfU4OKTrLWbS1Lug==
Last-Modified: Sat, 13 Sep 2025 17:13:31 GMT
Accept-Ranges: bytes
Date: Fri, 09 Jan 2026 12:13:40 GMT
Etag: "0x8DDF2E8DD8750D4"
Via: 1.1 2be97027a80b483d863e32bd7fe334e2.cloudfront.net (CloudFront)
Alt-Svc: h3=":443"; ma=86400
Age: 2
X-Cache: Hit from cloudfront
X-Amz-Cf-Pop: AMS58-P2
X-Amz-Cf-Id: F9TIRF_xxvb0Izk_gitYz8TGlEoQVheZy07uZmE0uePMLlt2VBAqbw==
Page title: Danny Bain - from first principals
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta property="og:title" content="Danny Bain - from first principals">
<meta property="og:description" content="Solver, enthusiast, and learner in Seattle. Expert in distributed systems, networking, storage, security, privacy and infra.">
<meta property="og:image" content="https://bain.org/danny/head-90x90.bmp">
<meta property="og:url" content="https://bain.org/danny">
<meta property="og:type" content="website">
<title>Danny Bain - from first principals</title>
<style>
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
body {
font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
line-height: 1.6;
color: #ffffff;
background: linear-gradient(135deg, #0f0f0f 0%, #1a1a2e 50%, #16213e 100%);
overflow-x: hidden;
}
.container {
max-width: 1200px;
margin: 0 auto;
padding: 0 20px;
}
/* Navigation */
nav {
position: fixed;
top: 0;
width: 100%;
background: rgba(15, 15, 15, 0.9);
backdrop-filter: blur(10px);
z-index: 1000;
transition: all 0.3s ease;
}
nav.scrolled {
background: rgba(15, 15, 15, 0.95);
box-shadow: 0 2px 20px rgba(0, 0, 0, 0.3);
}
.nav-container {
display: flex;
justify-content: space-between;
align-items: center;
padding: 1rem 2rem;
}
.logo {
font-size: 1.5rem;
font-weight: 700;
background: linear-gradient(45deg, #00f5ff, #ff00f5);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
}
.nav-links {
display: flex;
list-style: none;
gap: 2rem;
}
.nav-links a {
color: #ffffff;
text-decoration: none;
transition: all 0.3s ease;
position: relative;
}
.nav-links a:hover {
color: #00f5ff;
}
.nav-links a::after {
content: '';
position: absolute;
bottom: -5px;
left: 0;
width: 0;
height: 2px;
background: linear-gradient(45deg, #00f5ff, #ff00f5);
transition: width 0.3s ease;
}
.nav-links a:hover::after {
width: 100%;
}
/* Hero Section */
.hero {
height: 100vh;
display: flex;
align-items: center;
position: relative;
overflow: hidden;
}
.hero::before {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background:
radial-gradient(circle at 20% 80%, rgba(120, 119, 198, 0.3) 0%, transparent 50%),
radial-gradient(circle at 80% 20%, rgba(255, 119, 198, 0.3) 0%, transparent 50%);
animation: pulse 4s ease-in-out infinite;
}
@keyframes pulse {
0%, 100% { opacity: 0.5; }
50% { opacity: 0.8; }
}
.hero-content {
position: relative;
z-index: 2;
}
.hero h1 {
font-size: clamp(3rem, 8vw, 6rem);
font-weight: 800;
margin-bottom: 1rem;
background: linear-gradient(45deg, #ffffff, #00f5ff, #ff00f5);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
animation: fad
Open service 52.84.174.72:80 · dan.vg
2025-12-23 07:08
HTTP/1.1 200 OK
Server: CloudFront
Content-Type: text/html
Content-Length: 20271
Connection: close
Content-Md5: GQUB2MpfU4OKTrLWbS1Lug==
Last-Modified: Sat, 13 Sep 2025 17:13:31 GMT
Accept-Ranges: bytes
Etag: "0x8DDF2E8DD8750D4"
Date: Tue, 23 Dec 2025 07:08:00 GMT
Via: 1.1 f732889a761ee496e041d15e73c58bd6.cloudfront.net (CloudFront)
Alt-Svc: h3=":443"; ma=86400
Age: 1
X-Cache: Hit from cloudfront
X-Amz-Cf-Pop: CDG50-P1
X-Amz-Cf-Id: C5GvYenXXjy9j3i_RqnLJrFgYitjoqzdozSI5jMnpBDL2H_ove2EmA==
Page title: Danny Bain - from first principals
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta property="og:title" content="Danny Bain - from first principals">
<meta property="og:description" content="Solver, enthusiast, and learner in Seattle. Expert in distributed systems, networking, storage, security, privacy and infra.">
<meta property="og:image" content="https://bain.org/danny/head-90x90.bmp">
<meta property="og:url" content="https://bain.org/danny">
<meta property="og:type" content="website">
<title>Danny Bain - from first principals</title>
<style>
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
body {
font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
line-height: 1.6;
color: #ffffff;
background: linear-gradient(135deg, #0f0f0f 0%, #1a1a2e 50%, #16213e 100%);
overflow-x: hidden;
}
.container {
max-width: 1200px;
margin: 0 auto;
padding: 0 20px;
}
/* Navigation */
nav {
position: fixed;
top: 0;
width: 100%;
background: rgba(15, 15, 15, 0.9);
backdrop-filter: blur(10px);
z-index: 1000;
transition: all 0.3s ease;
}
nav.scrolled {
background: rgba(15, 15, 15, 0.95);
box-shadow: 0 2px 20px rgba(0, 0, 0, 0.3);
}
.nav-container {
display: flex;
justify-content: space-between;
align-items: center;
padding: 1rem 2rem;
}
.logo {
font-size: 1.5rem;
font-weight: 700;
background: linear-gradient(45deg, #00f5ff, #ff00f5);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
}
.nav-links {
display: flex;
list-style: none;
gap: 2rem;
}
.nav-links a {
color: #ffffff;
text-decoration: none;
transition: all 0.3s ease;
position: relative;
}
.nav-links a:hover {
color: #00f5ff;
}
.nav-links a::after {
content: '';
position: absolute;
bottom: -5px;
left: 0;
width: 0;
height: 2px;
background: linear-gradient(45deg, #00f5ff, #ff00f5);
transition: width 0.3s ease;
}
.nav-links a:hover::after {
width: 100%;
}
/* Hero Section */
.hero {
height: 100vh;
display: flex;
align-items: center;
position: relative;
overflow: hidden;
}
.hero::before {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background:
radial-gradient(circle at 20% 80%, rgba(120, 119, 198, 0.3) 0%, transparent 50%),
radial-gradient(circle at 80% 20%, rgba(255, 119, 198, 0.3) 0%, transparent 50%);
animation: pulse 4s ease-in-out infinite;
}
@keyframes pulse {
0%, 100% { opacity: 0.5; }
50% { opacity: 0.8; }
}
.hero-content {
position: relative;
z-index: 2;
}
.hero h1 {
font-size: clamp(3rem, 8vw, 6rem);
font-weight: 800;
margin-bottom: 1rem;
background: linear-gradient(45deg, #ffffff, #00f5ff, #ff00f5);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
animation: fad