:root {
--bg: #f5f1ea;
--bg-alt: #ebe5d8;
--paper: #fbf8f1;
--ink: #1a1714;
--ink-soft: #423d36;
--ink-muted: #8a8479;
--accent: #c4422a;
--accent-soft: #e8a89a;
--accent-bg: #fce8e2;
--green: #4a7c59;
--line: rgba(26, 23, 20, 0.12);
--line-strong: rgba(26, 23, 20, 0.25);
}
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
html {
scroll-behavior: smooth;
}
body {
background: var(--bg);
color: var(--ink);
font-family: 'Inter Tight', system-ui, sans-serif;
font-weight: 400;
line-height: 1.5;
overflow-x: hidden;
-webkit-font-smoothing: antialiased;
}
body::before {
content: '';
position: fixed;
inset: 0;
pointer-events: none;
z-index: 1000;
opacity: 0.35;
background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3CfeColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.07 0'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)'/%3E%3C/svg%3E");
}
::selection {
background: var(--accent);
color: var(--paper);
}
a {
color: inherit;
text-decoration: none;
} nav {
position: fixed;
top: 0;
left: 0;
right: 0;
z-index: 100;
padding: 1.2rem 3rem;
display: flex;
justify-content: space-between;
align-items: center;
backdrop-filter: blur(12px);
background: rgba(245, 241, 234, 0.75);
border-bottom: 1px solid transparent;
transition: all 0.3s ease;
}
nav.scrolled {
border-bottom-color: var(--line);
padding: 0.8rem 3rem;
}
.logo {
font-family: 'Fraunces', serif;
font-size: 1.05rem;
font-weight: 500;
letter-spacing: -0.02em;
font-style: italic;
display: flex;
align-items: center;
gap: 0.6rem;
}
.logo-dot {
width: 8px;
height: 8px;
border-radius: 50%;
background: var(--green);
box-shadow: 0 0 0 4px rgba(74, 124, 89, 0.2);
animation: pulse 2s ease-in-out infinite;
}
@keyframes pulse {
0%,
100% {
box-shadow: 0 0 0 4px rgba(74, 124, 89, 0.2);
}
50% {
box-shadow: 0 0 0 8px rgba(74, 124, 89, 0.05);
}
}
.nav-links {
display: flex;
gap: 2rem;
list-style: none;
font-size: 0.85rem;
font-weight: 400;
}
.nav-links a {
color: var(--ink-soft);
position: relative;
transition: color 0.2s ease;
}
.nav-links a:hover {
color: var(--ink);
}
.nav-links a::after {
content: '';
position: absolute;
bottom: -4px;
left: 0;
width: 0;
height: 1px;
background: var(--accent);
transition: width 0.3s ease;
}
.nav-links a:hover::after {
width: 100%;
}
.nav-cta {
background: var(--ink);
color: var(--bg);
padding: 0.55rem 1.1rem;
border-radius: 100px;
font-size: 0.8rem;
font-weight: 500;
transition: all 0.25s ease;
display: inline-flex;
align-items: center;
gap: 0.4rem;
}
.nav-cta:hover {
background: var(--accent);
transform: translateY(-1px);
}
.nav-toggle {
display: none;
background: transparent;
border: 1px solid var(--line-strong);
width: 36px;
height: 36px;
border-radius: 50%;
cursor: pointer;
align-items: center;
justify-content: center;
flex-direction: column;
gap: 4px;
padding: 0;
}
.nav-toggle span {
display: block;
width: 14px;
height: 1.5px;
background: var(--ink);
transition: all 0.3s ease;
} .hero {
min-height: 100vh;
padding: 8rem 3rem 4rem;
display: grid;
grid-template-columns: 1fr;
gap: 3rem;
position: relative;
}
.hero-status {
display: inline-flex;
align-items: center;
gap: 0.6rem;
background: rgba(74, 124, 89, 0.1);
color: var(--green);
padding: 0.5rem 1rem;
border-radius: 100px;
font-family: 'JetBrains Mono', monospace;
font-size: 0.75rem;
font-weight: 500;
width: fit-content;
border: 1px solid rgba(74, 124, 89, 0.2);
opacity: 0;
transform: translateY(20px);
animation: fadeUp 0.8s ease 0.1s forwards;
}
.hero-status .dot {
width: 8px;
height: 8px;
border-radius: 50%;
background: var(--green);
animation: pulse 2s ease-in-out infinite;
}
@keyframes fadeUp {
to {
opacity: 1;
transform: translateY(0);
}
}
.hero-title {
font-family: 'Fraunces', serif;
font-weight: 300;
font-size: clamp(2.8rem, 8vw, 7.5rem);
line-height: 0.95;
letter-spacing: -0.04em;
color: var(--ink);
max-width: 14ch;
}
.hero-title .word {
display: inline-block;
overflow: hidden;
vertical-align: top;
}
.hero-title .word-inner {
display: inline-block;
transform: translateY(110%);
animation: wordReveal 0.9s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}
@keyframes wordReveal {
to {
transform: translateY(0);
}
}
.hero-title .italic {
font-style: italic;
font-weight: 400;
color: var(--accent);
}
.hero-subtitle {
font-family: 'Fraunces', serif;
font-style: italic;
font-weight: 400;
font-size: clamp(1.1rem, 1.6vw, 1.4rem);
color: var(--ink-soft);
max-width: 50ch;
line-height: 1.5;
opacity: 0;
transform: translateY(20px);
animation: fadeUp 0.8s ease 1.4s forwards;
}
.hero-meta-row {
display: flex;
flex-wrap: wrap;
gap: 2.5rem;
align-items: baseline;
padding-top: 2rem;
border-top: 1px solid var(--line);
margin-top: 1rem;
opacity: 0;
transform: translateY(20px);
animation: fadeUp 0.8s ease 1.7s forwards;
}
.meta-item {
display: flex;
flex-direction: column;
gap: 0.3rem;
}
.meta-label {
font-family: 'JetBrains Mono', monospace;
font-size: 0.7rem;
color: var(--ink-muted);
text-transform: uppercase;
letter-spacing: 0.15em;
}
.meta-value {
font-size: 0.95rem;
color: var(--ink);
font-weight: 500;
}
.hero-cta {
display: flex;
gap: 0.8rem;
flex-wrap: wrap;
margin-top: 1rem;
opacity: 0;
transform: translateY(20px);
animation: fadeUp 0.8s ease 1.6s forwards;
} .btn {
display: inline-flex;
align-items: center;
gap: 0.55rem;
padding: 0.7rem 1.4rem;
font-size: 0.85rem;
font-weight: 500;
border-radius: 100px;
transition: all 0.3s cubic-bezier(0.22, 1, 0.36, 1);
border: 1px solid transparent;
cursor: pointer;
font-family: inherit;
line-height: 1;
letter-spacing: -0.01em;
}
.btn-primary {
background: var(--ink);
color: var(--bg);
}
.btn-primary:hover {
background: var(--accent);
transform: translateY(-2px);
box-shadow: 0 10px 25px -8px rgba(196, 66, 42, 0.4);
}
.btn-secondary {
background: transparent;
color: var(--ink);
border-color: var(--line-strong);
}
.btn-secondary:hover {
background: var(--ink);
color: var(--bg);
border-color: var(--ink);
}
.btn .arrow {
transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1);
display: inline-block;
}
.btn:hover .arrow {
transform: translateX(4px);
} .ticker {
background: var(--ink);
color: var(--bg);
padding: 1.2rem 0;
overflow: hidden;
border-top: 1px solid var(--ink);
border-bottom: 1px solid var(--ink);
}
.ticker-track {
display: flex;
gap: 3rem;
animation: ticker 35s linear infinite;
white-space: nowrap;
width: max-content;
}
@keyframes ticker {
0% {
transform: translateX(0);
}
100% {
transform: translateX(-50%);
}
}
.ticker-item {
font-family: 'Fraunces', serif;
font-size: 1.3rem;
font-weight: 400;
letter-spacing: -0.01em;
display: inline-flex;
align-items: center;
gap: 3rem;
}
.ticker-item::after {
content: '✦';
color: var(--accent-soft);
font-size: 0.9rem;
}
.ticker-item .italic {
font-style: italic;
color: var(--accent-soft);
} section {
padding: 8rem 3rem;
position: relative;
}
.section-header {
display: grid;
grid-template-columns: 200px 1fr;
gap: 2rem;
margin-bottom: 4rem;
align-items: baseline;
}
.section-num {
font-family: 'JetBrains Mono', monospace;
font-size: 0.75rem;
color: var(--ink-muted);
text-transform: uppercase;
letter-spacing: 0.15em;
}
.section-title {
font-family: 'Fraunces', serif;
font-size: clamp(2.3rem, 4.5vw, 3.8rem);
font-weight: 300;
line-height: 1;
letter-spacing: -0.03em;
}
.section-title .italic {
font-style: italic;
color: var(--accent);
position: relative;
display: inline-block;
}
.section-title .italic::after {
content: '';
position: absolute;
left: 0;
bottom: 0.05em;
width: 0;
height: 2px;
background: var(--accent);
transition: width 0.6s cubic-bezier(0.22, 1, 0.36, 1);
}
.section-title:hover .italic::after {
width: 100%;
} .about {
background: var(--paper);
border-top: 1px solid var(--line);
border-bottom: 1px solid var(--line);
}
.about-content {
display: grid;
grid-template-columns: 200px 1fr 1fr;
gap: 3rem;
align-items: start;
}
.about-label {
font-family: 'JetBrains Mono', monospace;
font-size: 0.7rem;
color: var(--ink-muted);
text-transform: uppercase;
letter-spacing: 0.15em;
}
.about-lead {
font-family: 'Fraunces', serif;
font-size: clamp(1.5rem, 2.4vw, 2.1rem);
font-weight: 300;
line-height: 1.3;
letter-spacing: -0.02em;
}
.about-lead em {
font-style: italic;
color: var(--accent);
}
.about-text {
font-size: 1rem;
line-height: 1.75;
color: var(--ink-soft);
}
.about-text p+p {
margin-top: 1rem;
}
.about-stats {
display: grid;
grid-template-columns: repeat(4, 1fr);
gap: 2rem;
margin-top: 5rem;
padding-top: 3rem;
border-top: 1px solid var(--line);
}
.stat-num {
font-family: 'Fraunces', serif;
font-size: 3.5rem;
font-weight: 300;
line-height: 1;
letter-spacing: -0.03em;
display: flex;
align-items: baseline;
}
.stat-num .italic {
font-style: italic;
color: var(--accent);
}
.stat-label {
font-family: 'JetBrains Mono', monospace;
font-size: 0.7rem;
color: var(--ink-muted);
text-transform: uppercase;
letter-spacing: 0.15em;
margin-top: 0.6rem;
} .experience-list {
border-top: 1px solid var(--ink);
}
.exp-item {
display: grid;
grid-template-columns: 200px 1fr 200px 40px;
gap: 3rem;
padding: 2.5rem 1.5rem;
border-bottom: 1px solid var(--line);
align-items: start;
position: relative;
cursor: pointer;
transition: all 0.5s cubic-bezier(0.22, 1, 0.36, 1);
overflow: hidden;
} .exp-item::before {
content: '';
position: absolute;
inset: 0;
background: linear-gradient(90deg, var(--paper) 0%, transparent 100%);
transform: translateX(-100%);
transition: transform 0.6s cubic-bezier(0.22, 1, 0.36, 1);
z-index: 0;
} .exp-item::after {
content: '';
position: absolute;
left: 0;
top: 50%;
transform: translateY(-50%);
width: 3px;
height: 0;
background: var(--accent);
transition: height 0.5s cubic-bezier(0.22, 1, 0.36, 1);
z-index: 1;
}
.exp-item>* {
position: relative;
z-index: 2;
}
.exp-item:hover::before {
transform: translateX(0);
}
.exp-item:hover::after {
height: 60%;
}
.exp-item:hover .exp-arrow {
opacity: 1;
transform: translate(0, 0);
color: var(--accent);
}
.exp-item:hover .exp-role {
color: var(--accent);
transform: translateX(4px);
}
.exp-item:hover .exp-period .duration {
background: var(--accent);
color: var(--paper);
}
.exp-period {
font-family: 'JetBrains Mono', monospace;
font-size: 0.75rem;
color: var(--ink-muted);
text-transform: uppercase;
letter-spacing: 0.1em;
}
.exp-period .duration {
display: inline-block;
margin-top: 0.5rem;
padding: 0.25rem 0.6rem;
background: var(--bg-alt);
color: var(--accent);
border-radius: 100px;
font-weight: 500;
transition: all 0.3s ease;
}
.exp-role {
font-family: 'Fraunces', serif;
font-size: 1.6rem;
font-weight: 400;
line-height: 1.2;
margin-bottom: 0.25rem;
transition: all 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}
.exp-company {
font-family: 'Fraunces', serif;
font-style: italic;
color: var(--accent);
font-size: 1rem;
margin-bottom: 1rem;
}
.exp-tasks {
list-style: none;
font-size: 0.9rem;
color: var(--ink-soft);
line-height: 1.75;
}
.exp-tasks li {
padding-left: 1.2rem;
position: relative;
transition: transform 0.3s ease;
}
.exp-item:hover .exp-tasks li {
transform: translateX(2px);
}
.exp-item:hover .exp-tasks li:nth-child(2) {
transition-delay: 0.05s;
}
.exp-item:hover .exp-tasks li:nth-child(3) {
transition-delay: 0.1s;
}
.exp-item:hover .exp-tasks li:nth-child(4) {
transition-delay: 0.15s;
}
.exp-item:hover .exp-tasks li:nth-child(5) {
transition-delay: 0.2s;
}
.exp-item:hover .exp-tasks li:nth-child(6) {
transition-delay: 0.25s;
}
.exp-tasks li::before {
content: '—';
position: absolute;
left: 0;
color: var(--ink-muted);
transition: color 0.3s ease;
}
.exp-item:hover .exp-tasks li::before {
color: var(--accent);
}
.exp-location {
font-family: 'JetBrains Mono', monospace;
font-size: 0.7rem;
color: var(--ink-muted);
text-transform: uppercase;
letter-spacing: 0.1em;
text-align: right;
}
.exp-arrow {
font-family: 'Fraunces', serif;
font-size: 1.4rem;
font-style: italic;
color: var(--ink-muted);
opacity: 0;
transform: translate(-8px, 4px);
transition: all 0.4s cubic-bezier(0.22, 1, 0.36, 1);
align-self: center;
text-align: right;
} .projects {
background: var(--paper);
}
.privacy-note {
background: var(--bg-alt);
border: 1px solid var(--line);
border-radius: 12px;
padding: 1.2rem 1.5rem;
margin-bottom: 3rem;
display: flex;
gap: 1rem;
align-items: flex-start;
font-size: 0.88rem;
color: var(--ink-soft);
line-height: 1.6;
}
.privacy-note-icon {
flex-shrink: 0;
width: 28px;
height: 28px;
border-radius: 50%;
background: var(--ink);
color: var(--bg);
display: flex;
align-items: center;
justify-content: center;
font-family: 'Fraunces', serif;
font-style: italic;
font-size: 0.95rem;
}
.project-grid {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 2rem;
}
.project-card {
background: var(--bg);
border: 1px solid var(--line);
border-radius: 4px;
overflow: hidden;
transition: all 0.4s cubic-bezier(0.22, 1, 0.36, 1);
display: flex;
flex-direction: column;
position: relative;
}
.project-card:hover {
transform: translateY(-6px);
border-color: var(--ink);
box-shadow: 0 20px 40px -15px rgba(26, 23, 20, 0.15);
}
.project-mockup {
aspect-ratio: 16 / 10;
position: relative;
overflow: hidden;
border-bottom: 1px solid var(--line);
}
.project-mockup-inner {
position: absolute;
inset: 0;
transition: transform 0.6s cubic-bezier(0.22, 1, 0.36, 1);
width: 100%;
height: 100%;
}
.project-mockup-inner img {
width: 100%;
object-fit: cover;
}
.project-live-btn {
padding-top: 1.25rem;
}
.project-card:hover .project-mockup-inner {
transform: scale(1.04);
} .project-badge {
position: absolute;
top: 1rem;
right: 1rem;
background: var(--ink);
color: var(--bg);
padding: 0.4rem 0.9rem;
border-radius: 100px;
font-family: 'JetBrains Mono', monospace;
font-size: 0.65rem;
text-transform: uppercase;
letter-spacing: 0.1em;
opacity: 0;
transform: translateY(-8px);
transition: all 0.4s cubic-bezier(0.22, 1, 0.36, 1);
z-index: 5;
pointer-events: none;
}
.project-card:hover .project-badge {
opacity: 1;
transform: translateY(0);
} .mockup-multisite {
background: linear-gradient(135deg, #2d3e50 0%, #1a2332 100%);
padding: 1.5rem;
display: grid;
grid-template-columns: repeat(3, 1fr);
grid-template-rows: repeat(2, 1fr);
gap: 0.6rem;
}
.mockup-multisite .ms-card {
background: rgba(255, 255, 255, 0.08);
border: 1px solid rgba(255, 255, 255, 0.15);
border-radius: 4px;
padding: 0.6rem;
display: flex;
flex-direction: column;
gap: 0.3rem;
}
.mockup-multisite .ms-card.main {
background: rgba(196, 66, 42, 0.3);
border-color: rgba(196, 66, 42, 0.6);
}
.ms-card .ms-bar {
height: 3px;
background: rgba(255, 255, 255, 0.4);
border-radius: 2px;
width: 60%;
}
.ms-card .ms-bar.short {
width: 40%;
}
.ms-card .ms-bar.long {
width: 80%;
} .mockup-woo {
background: linear-gradient(180deg, #faf6ee 0%, #f0e9d8 100%);
padding: 1.2rem;
display: flex;
flex-direction: column;
gap: 0.7rem;
}
.mockup-woo .woo-header {
display: flex;
justify-content: space-between;
align-items: center;
padding-bottom: 0.6rem;
border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}
.mockup-woo .woo-logo {
width: 40px;
height: 4px;
background: var(--ink);
border-radius: 2px;
}
.mockup-woo .woo-cart {
width: 18px;
height: 18px;
border: 1.5px solid var(--ink);
border-radius: 3px;
position: relative;
}
.mockup-woo .woo-cart::after {
content: '3';
position: absolute;
top: -6px;
right: -6px;
background: var(--accent);
color: white;
font-size: 8px;
width: 12px;
height: 12px;
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
}
.mockup-woo .woo-products {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 0.5rem;
flex: 1;
}
.mockup-woo .woo-product {
background: white;
border-radius: 3px;
padding: 0.4rem;
display: flex;
flex-direction: column;
gap: 0.3rem;
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.04);
}
.mockup-woo .woo-img {
aspect-ratio: 1;
background: linear-gradient(135deg, #d4c5a3, #b8a584);
border-radius: 2px;
}
.mockup-woo .woo-product:nth-child(2) .woo-img {
background: linear-gradient(135deg, #c4422a, #a03520);
}
.mockup-woo .woo-product:nth-child(3) .woo-img {
background: linear-gradient(135deg, #4a7c59, #3a6347);
}
.mockup-woo .woo-line {
height: 2px;
background: rgba(0, 0, 0, 0.15);
border-radius: 1px;
}
.mockup-woo .woo-price {
height: 4px;
background: var(--accent);
border-radius: 1px;
width: 50%;
} .mockup-theme {
background: #1a1714;
padding: 1.2rem;
display: flex;
flex-direction: column;
gap: 0.8rem;
color: white;
position: relative;
}
.mockup-theme::before {
content: '';
position: absolute;
inset: 0;
background: radial-gradient(circle at 30% 30%, rgba(196, 66, 42, 0.2), transparent 50%);
}
.mockup-theme>* {
position: relative;
z-index: 1;
}
.mockup-theme .theme-nav {
display: flex;
justify-content: space-between;
padding-bottom: 0.6rem;
border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}
.mockup-theme .theme-logo {
font-family: 'Fraunces', serif;
font-style: italic;
font-size: 0.7rem;
color: var(--accent-soft);
}
.mockup-theme .theme-menu {
display: flex;
gap: 0.6rem;
}
.mockup-theme .theme-menu span {
width: 18px;
height: 2px;
background: rgba(255, 255, 255, 0.3);
border-radius: 1px;
}
.mockup-theme .theme-hero {
flex: 1;
display: flex;
flex-direction: column;
justify-content: center;
gap: 0.4rem;
}
.mockup-theme .theme-title {
font-family: 'Fraunces', serif;
font-size: 1.3rem;
font-weight: 300;
letter-spacing: -0.02em;
line-height: 1;
}
.mockup-theme .theme-title em {
color: var(--accent-soft);
font-style: italic;
}
.mockup-theme .theme-text {
height: 2px;
background: rgba(255, 255, 255, 0.2);
width: 70%;
border-radius: 1px;
}
.mockup-theme .theme-text.short {
width: 50%;
}
.mockup-theme .theme-btn {
width: 60px;
height: 16px;
background: var(--accent);
border-radius: 100px;
margin-top: 0.4rem;
} .mockup-speed {
background: linear-gradient(180deg, #fff 0%, #f5f1ea 100%);
padding: 1.2rem;
display: flex;
flex-direction: column;
gap: 0.8rem;
}
.mockup-speed .speed-title {
font-family: 'JetBrains Mono', monospace;
font-size: 0.65rem;
color: var(--ink-muted);
text-transform: uppercase;
letter-spacing: 0.1em;
}
.mockup-speed .speed-scores {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 0.6rem;
flex: 1;
}
.mockup-speed .speed-score {
background: white;
border: 1px solid var(--line);
border-radius: 4px;
padding: 0.6rem;
display: flex;
align-items: center;
gap: 0.6rem;
}
.mockup-speed .speed-circle {
width: 36px;
height: 36px;
border-radius: 50%;
border: 3px solid var(--green);
display: flex;
align-items: center;
justify-content: center;
font-family: 'Fraunces', serif;
font-size: 0.9rem;
font-weight: 500;
color: var(--green);
flex-shrink: 0;
}
.mockup-speed .speed-score:nth-child(2) .speed-circle {
border-color: var(--green);
color: var(--green);
}
.mockup-speed .speed-score:nth-child(3) .speed-circle {
border-color: #d4a13a;
color: #d4a13a;
}
.mockup-speed .speed-score:nth-child(4) .speed-circle {
border-color: var(--green);
color: var(--green);
}
.mockup-speed .speed-info {
flex: 1;
display: flex;
flex-direction: column;
gap: 0.3rem;
}
.mockup-speed .speed-label {
font-size: 0.55rem;
color: var(--ink-muted);
text-transform: uppercase;
}
.mockup-speed .speed-bar {
height: 4px;
background: var(--bg-alt);
border-radius: 2px;
overflow: hidden;
}
.mockup-speed .speed-bar-fill {
height: 100%;
background: var(--green);
border-radius: 2px;
}
.project-body {
padding: 1.8rem;
flex: 1;
display: flex;
flex-direction: column;
}
.project-meta {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: 1rem;
}
.project-num {
font-family: 'JetBrains Mono', monospace;
font-size: 0.7rem;
color: var(--ink-muted);
letter-spacing: 0.15em;
}
.project-sector {
font-family: 'JetBrains Mono', monospace;
font-size: 0.65rem;
color: var(--accent);
background: var(--accent-bg);
padding: 0.25rem 0.7rem;
border-radius: 100px;
text-transform: uppercase;
letter-spacing: 0.1em;
font-weight: 500;
}
.project-title {
font-family: 'Fraunces', serif;
font-size: 1.7rem;
font-weight: 400;
line-height: 1.15;
margin-bottom: 0.8rem;
letter-spacing: -0.02em;
}
.project-title .italic {
font-style: italic;
color: var(--accent);
}
.project-desc {
font-size: 0.92rem;
color: var(--ink-soft);
line-height: 1.65;
margin-bottom: 1.2rem;
flex: 1;
}
.project-results {
display: flex;
gap: 1.2rem;
margin-bottom: 1.2rem;
padding: 1rem 0;
border-top: 1px solid var(--line);
border-bottom: 1px solid var(--line);
}
.result-item {
flex: 1;
}
.result-num {
font-family: 'Fraunces', serif;
font-size: 1.6rem;
font-weight: 400;
color: var(--accent);
line-height: 1;
margin-bottom: 0.2rem;
}
.result-label {
font-family: 'JetBrains Mono', monospace;
font-size: 0.65rem;
color: var(--ink-muted);
text-transform: uppercase;
letter-spacing: 0.1em;
}
.project-tech {
display: flex;
gap: 0.4rem;
flex-wrap: wrap;
}
.project-tech span {
font-family: 'JetBrains Mono', monospace;
font-size: 0.7rem;
color: var(--ink-soft);
padding: 0.3rem 0.7rem;
border: 1px solid var(--line);
border-radius: 4px;
} .blog {
background: var(--paper);
border-top: 1px solid var(--line);
border-bottom: 1px solid var(--line);
}
.blog-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 2rem;
margin-bottom: 3rem;
}
.blog-card {
background: var(--bg);
border: 1px solid var(--line);
border-radius: 4px;
overflow: hidden;
transition: all 0.4s cubic-bezier(0.22, 1, 0.36, 1);
display: flex;
flex-direction: column;
}
.blog-card:hover {
transform: translateY(-6px);
border-color: var(--ink);
box-shadow: 0 20px 40px -15px rgba(26, 23, 20, 0.15);
}
.blog-card-link {
display: flex;
flex-direction: column;
height: 100%;
text-decoration: none;
color: inherit;
}
.blog-card-image {
aspect-ratio: 16 / 10;
overflow: hidden;
border-bottom: 1px solid var(--line);
background: var(--bg-alt);
position: relative;
}
.blog-card-image img {
width: 100%;
height: 100%;
object-fit: cover;
display: block;
transition: transform 0.6s cubic-bezier(0.22, 1, 0.36, 1);
}
.blog-card:hover .blog-card-image img {
transform: scale(1.04);
} .blog-card-image-placeholder {
display: flex;
align-items: center;
justify-content: center;
}
.blog-card-image-placeholder.pattern-1 {
background:
radial-gradient(circle at 20% 30%, rgba(196, 66, 42, 0.12), transparent 50%),
radial-gradient(circle at 80% 70%, rgba(74, 124, 89, 0.08), transparent 50%),
linear-gradient(135deg, var(--bg-alt) 0%, var(--paper) 100%);
}
.blog-card-image-placeholder.pattern-2 {
background:
radial-gradient(circle at 70% 30%, rgba(196, 66, 42, 0.15), transparent 50%),
radial-gradient(circle at 30% 70%, rgba(196, 66, 42, 0.05), transparent 50%),
linear-gradient(180deg, var(--paper) 0%, var(--bg-alt) 100%);
}
.blog-card-image-placeholder.pattern-3 {
background:
radial-gradient(circle at 50% 50%, rgba(74, 124, 89, 0.1), transparent 60%),
linear-gradient(45deg, var(--bg-alt) 0%, var(--paper) 50%, var(--bg-alt) 100%);
}
.blog-card-image-placeholder span {
font-family: 'Fraunces', serif;
font-style: italic;
font-weight: 300;
font-size: 7rem;
color: var(--accent);
line-height: 1;
position: relative;
z-index: 1;
transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}
.blog-card:hover .blog-card-image-placeholder span {
transform: scale(1.08) rotate(-2deg);
}
.blog-card-body {
padding: 1.8rem;
flex: 1;
display: flex;
flex-direction: column;
}
.blog-card-meta {
display: flex;
gap: 1rem;
align-items: center;
margin-bottom: 1rem;
font-family: 'JetBrains Mono', monospace;
font-size: 0.7rem;
color: var(--ink-muted);
text-transform: uppercase;
letter-spacing: 0.1em;
}
.blog-card-readtime {
position: relative;
padding-left: 1rem;
}
.blog-card-readtime::before {
content: '·';
position: absolute;
left: 0;
color: var(--ink-muted);
}
.blog-card-title {
font-family: 'Fraunces', serif;
font-size: 1.4rem;
font-weight: 400;
line-height: 1.25;
letter-spacing: -0.02em;
color: var(--ink);
margin-bottom: 0.8rem;
transition: color 0.3s ease;
}
.blog-card:hover .blog-card-title {
color: var(--accent);
}
.blog-card-excerpt {
font-size: 0.92rem;
color: var(--ink-soft);
line-height: 1.65;
margin-bottom: 1.5rem;
flex: 1;
}
.blog-card-cta {
font-family: 'JetBrains Mono', monospace;
font-size: 0.72rem;
text-transform: uppercase;
letter-spacing: 0.15em;
color: var(--accent);
font-weight: 500;
display: inline-flex;
align-items: center;
gap: 0.5rem;
margin-top: auto;
}
.blog-card-cta .arrow {
transition: transform 0.3s ease;
display: inline-block;
}
.blog-card:hover .blog-card-cta .arrow {
transform: translateX(4px);
}
.blog-footer {
text-align: center;
} .article-cover-img {
width: 100%;
height: 100%;
object-fit: cover;
display: block;
} .author-avatar-img {
width: 40px;
height: 40px;
border-radius: 50%;
object-fit: cover;
}
.author-box-avatar-img {
width: 72px;
height: 72px;
border-radius: 50%;
object-fit: cover;
flex-shrink: 0;
} .skills {
background: var(--ink);
color: var(--bg);
}
.skills .section-num {
color: rgba(245, 241, 234, 0.5);
}
.skills .section-title {
color: var(--bg);
}
.skills .section-title .italic {
color: var(--accent-soft);
}
.skills .section-title .italic::after {
background: var(--accent-soft);
}
.skill-grid {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 0;
}
.skill-cat {
padding: 2.5rem;
border: 1px solid rgba(245, 241, 234, 0.1);
margin: -0.5px;
transition: background 0.3s ease;
}
.skill-cat:hover {
background: rgba(245, 241, 234, 0.04);
}
.skill-cat-num {
font-family: 'JetBrains Mono', monospace;
font-size: 0.7rem;
color: var(--accent-soft);
margin-bottom: 0.6rem;
letter-spacing: 0.15em;
}
.skill-cat-title {
font-family: 'Fraunces', serif;
font-style: italic;
font-size: 1.3rem;
color: var(--bg);
margin-bottom: 1.5rem;
}
.skill-tags {
display: flex;
flex-wrap: wrap;
gap: 0.5rem;
}
.skill-tag {
font-family: 'JetBrains Mono', monospace;
font-size: 0.75rem;
padding: 0.4rem 0.9rem;
background: rgba(245, 241, 234, 0.06);
border: 1px solid rgba(245, 241, 234, 0.15);
border-radius: 100px;
color: var(--bg);
transition: all 0.3s cubic-bezier(0.22, 1, 0.36, 1);
cursor: default;
}
.skill-tag:hover {
background: var(--accent);
border-color: var(--accent);
transform: translateY(-2px);
box-shadow: 0 6px 12px -4px rgba(196, 66, 42, 0.4);
} .quote-block {
padding: 8rem 3rem;
text-align: center;
background: var(--paper);
border-top: 1px solid var(--line);
border-bottom: 1px solid var(--line);
}
.quote-text {
font-family: 'Fraunces', serif;
font-style: italic;
font-weight: 300;
font-size: clamp(1.6rem, 3vw, 2.6rem);
line-height: 1.4;
letter-spacing: -0.02em;
max-width: 25ch;
margin: 0 auto 2rem;
color: var(--ink);
}
.quote-text::before,
.quote-text::after {
content: '"';
color: var(--accent);
font-family: 'Fraunces', serif;
}
.quote-attribution {
font-family: 'JetBrains Mono', monospace;
font-size: 0.75rem;
color: var(--ink-muted);
text-transform: uppercase;
letter-spacing: 0.2em;
} .contact {
background: var(--ink);
color: var(--bg);
}
.contact-header {
text-align: center;
margin-bottom: 4rem;
}
.contact .section-num {
color: rgba(245, 241, 234, 0.5);
}
.contact-title {
font-family: 'Fraunces', serif;
font-size: clamp(2.8rem, 6vw, 5.5rem);
font-weight: 300;
line-height: 0.95;
letter-spacing: -0.04em;
margin: 1rem 0;
color: var(--bg);
max-width: 18ch;
margin-left: auto;
margin-right: auto;
}
.contact-title .italic {
font-style: italic;
color: var(--accent-soft);
}
.contact-subtitle {
font-family: 'Fraunces', serif;
font-style: italic;
font-size: 1.1rem;
color: rgba(245, 241, 234, 0.7);
max-width: 50ch;
margin: 1rem auto 0;
line-height: 1.5;
}
.contact-form {
max-width: 700px;
margin: 0 auto;
}
.form-row {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 0;
border-bottom: 1px solid rgba(245, 241, 234, 0.15);
transition: border-color 0.4s ease;
position: relative;
}
.form-row::after {
content: '';
position: absolute;
bottom: -1px;
left: 0;
width: 0;
height: 1px;
background: var(--accent);
transition: width 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}
.form-row:focus-within::after {
width: 100%;
}
.form-group {
padding: 1.5rem 0;
}
.form-group+.form-group {
border-left: 1px solid rgba(245, 241, 234, 0.15);
padding-left: 1.5rem;
}
.form-row.full {
grid-template-columns: 1fr;
}
.form-label {
font-family: 'JetBrains Mono', monospace;
font-size: 0.7rem;
color: rgba(245, 241, 234, 0.5);
text-transform: uppercase;
letter-spacing: 0.15em;
margin-bottom: 0.5rem;
display: block;
transition: color 0.3s ease;
}
.form-group:focus-within .form-label {
color: var(--accent-soft);
}
.form-input,
.form-textarea {
width: 100%;
background: transparent;
border: none;
outline: none;
color: var(--bg);
font-family: 'Fraunces', serif;
font-size: 1.2rem;
font-weight: 300;
padding: 0;
resize: none;
}
.form-textarea {
min-height: 120px;
}
.form-input::placeholder,
.form-textarea::placeholder {
color: rgba(245, 241, 234, 0.3);
font-style: italic;
}
.form-submit {
margin-top: 3rem;
background: var(--accent);
border: 1px solid var(--accent);
color: var(--bg);
padding: 0.9rem 2rem;
font-family: 'JetBrains Mono', monospace;
font-size: 0.75rem;
text-transform: uppercase;
letter-spacing: 0.2em;
cursor: pointer;
transition: all 0.3s cubic-bezier(0.22, 1, 0.36, 1);
display: inline-flex;
align-items: center;
gap: 0.8rem;
border-radius: 100px;
}
.form-submit:hover {
background: transparent;
border-color: var(--bg);
transform: translateY(-2px);
}
.form-submit-arrow {
transition: transform 0.3s ease;
display: inline-block;
}
.form-submit:hover .form-submit-arrow {
transform: translateX(4px);
}
.direct-contact {
margin-top: 6rem;
padding-top: 4rem;
border-top: 1px solid rgba(245, 241, 234, 0.15);
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 2rem;
text-align: center;
}
.contact-method {
transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1);
}
.contact-method:hover {
transform: translateY(-3px);
}
.contact-method-label {
font-family: 'JetBrains Mono', monospace;
font-size: 0.7rem;
color: rgba(245, 241, 234, 0.5);
text-transform: uppercase;
letter-spacing: 0.15em;
margin-bottom: 0.75rem;
}
.contact-method-value {
font-family: 'Fraunces', serif;
font-size: 1.1rem;
color: var(--bg);
transition: color 0.2s ease;
}
.contact-method:hover .contact-method-value {
color: var(--accent-soft);
}
.response-time {
text-align: center;
margin-top: 3rem;
padding: 1rem;
font-family: 'JetBrains Mono', monospace;
font-size: 0.75rem;
color: rgba(245, 241, 234, 0.5);
text-transform: uppercase;
letter-spacing: 0.15em;
}
.response-time .green-dot {
display: inline-block;
width: 8px;
height: 8px;
border-radius: 50%;
background: var(--green);
margin-right: 0.5rem;
vertical-align: middle;
animation: pulse 2s ease-in-out infinite;
} footer {
background: var(--ink);
color: rgba(245, 241, 234, 0.5);
padding: 2rem 3rem;
border-top: 1px solid rgba(245, 241, 234, 0.1);
display: flex;
justify-content: space-between;
align-items: center;
font-family: 'JetBrains Mono', monospace;
font-size: 0.7rem;
text-transform: uppercase;
letter-spacing: 0.1em;
} .reveal {
opacity: 0;
transform: translateY(30px);
transition: opacity 0.8s ease, transform 0.8s ease;
}
.reveal.visible {
opacity: 1;
transform: translateY(0);
} .nav-drawer {
position: fixed;
top: 0;
right: 0;
bottom: 0;
width: 80%;
max-width: 320px;
background: var(--ink);
color: var(--bg);
padding: 5rem 2rem 2rem;
transform: translateX(100%);
transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
z-index: 99;
display: flex;
flex-direction: column;
}
.nav-drawer.open {
transform: translateX(0);
} .nav-drawer ul,
.nav-drawer .nav-drawer-menu {
list-style: none !important;
margin: 0 !important;
padding: 0 !important;
display: flex;
flex-direction: column;
gap: 0;
background: transparent !important;
border: none !important;
border-radius: 0 !important;
}
.nav-drawer ul li,
.nav-drawer .nav-drawer-menu li {
list-style: none !important;
margin: 0 !important;
padding: 0 !important;
background: transparent !important;
border: none !important;
border-radius: 0 !important;
display: block !important;
width: 100%;
} .nav-drawer ul li a,
.nav-drawer .nav-drawer-menu li a {
display: block !important;
font-family: 'Fraunces', serif !important;
font-size: 1.5rem !important;
font-weight: 400 !important;
color: var(--bg) !important;
padding: 1rem 0 !important;
border: none !important;
border-bottom: 1px solid rgba(245, 241, 234, 0.1) !important;
border-radius: 0 !important;
background: transparent !important;
text-align: left !important;
text-decoration: none !important;
transition: color 0.2s ease, padding 0.3s ease !important;
width: 100%;
box-sizing: border-box;
}
.nav-drawer ul li a:hover,
.nav-drawer .nav-drawer-menu li a:hover {
color: var(--accent-soft) !important;
padding-left: 0.5rem !important;
} .nav-drawer .nav-drawer-cta {
display: block;
margin-top: auto;
padding: 0.9rem 1.4rem !important;
background: var(--accent) !important;
color: var(--bg) !important;
border-radius: 100px !important;
text-align: center !important;
font-family: 'Inter Tight', sans-serif !important;
font-size: 0.9rem !important;
font-weight: 500 !important;
text-decoration: none !important;
border-bottom: none !important;
transition: all 0.25s ease !important;
}
.nav-drawer .nav-drawer-cta:hover {
background: var(--bg) !important;
color: var(--ink) !important;
padding-left: 1.4rem !important;
} @media (max-width: 900px) {
nav {
padding: 1rem 1.5rem;
}
nav.scrolled {
padding: 0.7rem 1.5rem;
}
.nav-links {
display: none;
}
.nav-cta {
display: none;
}
.nav-toggle {
display: flex;
}
section {
padding: 5rem 1.5rem;
}
.hero {
padding: 7rem 1.5rem 3rem;
}
.section-header,
.about-content {
grid-template-columns: 1fr;
gap: 1rem;
}
.exp-item {
grid-template-columns: 1fr;
gap: 1rem;
padding: 2rem 1rem;
}
.exp-item:hover {
padding: 2rem 1rem 2rem 1.2rem;
}
.exp-location {
text-align: left;
}
.exp-arrow {
display: none;
}
.skill-grid,
.project-grid,
.direct-contact,
.blog-grid {
grid-template-columns: 1fr;
}
.about-stats {
grid-template-columns: 1fr 1fr;
}
.form-row {
grid-template-columns: 1fr;
}
.form-group+.form-group {
border-left: none;
padding-left: 0;
border-top: 1px solid rgba(245, 241, 234, 0.15);
}
.hero-meta-row {
gap: 1.5rem;
}
.quote-block {
padding: 5rem 1.5rem;
}
footer {
flex-direction: column;
gap: 1rem;
text-align: center;
}
.privacy-note {
padding: 1rem;
}
} .error-404 {
min-height: 100vh;
padding: 8rem 3rem 4rem;
display: flex;
align-items: center;
justify-content: center;
position: relative;
overflow: hidden;
} .error-404::before,
.error-404::after {
content: '';
position: absolute;
pointer-events: none;
}
.error-404::before {
top: 20%;
left: -10%;
width: 40%;
height: 1px;
background: linear-gradient(90deg, transparent, var(--accent), transparent);
opacity: 0.3;
animation: errorLine 8s ease-in-out infinite;
}
.error-404::after {
bottom: 25%;
right: -10%;
width: 50%;
height: 1px;
background: linear-gradient(90deg, transparent, var(--ink-muted), transparent);
opacity: 0.2;
animation: errorLine 10s ease-in-out infinite reverse;
}
@keyframes errorLine {
0%,
100% {
transform: translateX(0);
}
50% {
transform: translateX(20%);
}
}
.error-404-inner {
max-width: 700px;
text-align: center;
position: relative;
z-index: 1;
}
.error-404-status {
display: inline-flex;
align-items: center;
gap: 0.6rem;
background: var(--accent-bg);
color: var(--accent);
padding: 0.5rem 1rem;
border-radius: 100px;
font-family: 'JetBrains Mono', monospace;
font-size: 0.75rem;
font-weight: 500;
margin-bottom: 2rem;
border: 1px solid rgba(196, 66, 42, 0.2);
}
.error-404-status .dot {
width: 8px;
height: 8px;
border-radius: 50%;
background: var(--accent);
animation: pulse 2s ease-in-out infinite;
}
.error-404-number {
font-family: 'Fraunces', serif;
font-weight: 300;
font-size: clamp(8rem, 22vw, 18rem);
line-height: 0.85;
letter-spacing: -0.06em;
color: var(--ink);
margin-bottom: 2rem;
display: flex;
justify-content: center;
align-items: center;
}
.error-404-number .digit {
display: inline-block;
animation: digitFloat 4s ease-in-out infinite;
}
.error-404-number .digit:nth-child(2) {
font-style: italic;
color: var(--accent);
animation-delay: 0.5s;
}
.error-404-number .digit:nth-child(3) {
animation-delay: 1s;
}
@keyframes digitFloat {
0%,
100% {
transform: translateY(0);
}
50% {
transform: translateY(-12px);
}
}
.error-404-title {
font-family: 'Fraunces', serif;
font-weight: 300;
font-size: clamp(1.6rem, 3vw, 2.4rem);
line-height: 1.25;
letter-spacing: -0.02em;
color: var(--ink);
margin-bottom: 1rem;
}
.error-404-title .italic {
font-style: italic;
color: var(--accent);
}
.error-404-desc {
font-size: 1rem;
line-height: 1.7;
color: var(--ink-soft);
max-width: 50ch;
margin: 0 auto 2.5rem;
}
.error-404-cta {
display: flex;
gap: 0.8rem;
justify-content: center;
flex-wrap: wrap;
margin-bottom: 4rem;
}
.error-404-links {
padding-top: 2.5rem;
border-top: 1px solid var(--line);
}
.error-404-links-label {
font-family: 'JetBrains Mono', monospace;
font-size: 0.7rem;
color: var(--ink-muted);
text-transform: uppercase;
letter-spacing: 0.15em;
display: block;
margin-bottom: 1.2rem;
}
.error-404-links-list {
display: flex;
gap: 2rem;
justify-content: center;
flex-wrap: wrap;
}
.error-404-links-list a {
font-family: 'Fraunces', serif;
font-style: italic;
font-size: 1.05rem;
color: var(--ink-soft);
position: relative;
transition: color 0.2s ease;
text-decoration: none;
}
.error-404-links-list a::after {
content: '';
position: absolute;
left: 0;
bottom: -2px;
width: 0;
height: 1px;
background: var(--accent);
transition: width 0.3s ease;
}
.error-404-links-list a:hover {
color: var(--accent);
}
.error-404-links-list a:hover::after {
width: 100%;
} @media (max-width: 768px) {
.error-404 {
padding: 6rem 1.5rem 3rem;
}
.error-404-cta {
flex-direction: column;
align-items: center;
}
.error-404-cta .btn {
width: 100%;
max-width: 280px;
justify-content: center;
}
.error-404-links-list {
gap: 1rem 1.5rem;
}
}  .contact .wpcf7-form {
max-width: 700px;
margin: 0 auto;
} .contact .wpcf7-form p {
margin: 0;
} .contact .wpcf7-form .wpcf7-form-control-wrap {
display: block;
width: 100%;
} .contact .wpcf7-response-output {
margin: 2rem auto 0 !important;
max-width: 700px;
padding: 1rem 1.5rem !important;
border-radius: 8px !important;
font-family: 'Inter Tight', sans-serif !important;
font-size: 0.9rem !important;
border: 1px solid !important;
} .contact .wpcf7 form.sent .wpcf7-response-output {
border-color: var(--green) !important;
background: rgba(74, 124, 89, 0.1) !important;
color: var(--accent-soft) !important;
} .contact .wpcf7 form.invalid .wpcf7-response-output,
.contact .wpcf7 form.failed .wpcf7-response-output {
border-color: var(--accent) !important;
background: rgba(196, 66, 42, 0.15) !important;
color: var(--accent-soft) !important;
} .contact .wpcf7-not-valid-tip {
color: var(--accent-soft) !important;
font-family: 'JetBrains Mono', monospace !important;
font-size: 0.7rem !important;
text-transform: uppercase !important;
letter-spacing: 0.1em !important;
margin-top: 0.5rem !important;
display: block !important;
} .contact .wpcf7-spinner {
background-color: var(--accent-soft) !important;
margin-left: 1rem !important;
} .contact .wpcf7-submit {
font-family: 'JetBrains Mono', monospace !important;
}
@media (min-width: 1024px) {
#iletisim form {
max-width: 75%;
margin: 0 auto;
}
} .blog-header {
padding: 9rem 3rem 5rem;
border-bottom: 1px solid var(--line);
background: var(--paper);
}
.blog-header-inner {
max-width: 1200px;
margin: 0 auto;
}
.blog-breadcrumb {
display: flex;
align-items: center;
gap: 0.6rem;
font-family: 'JetBrains Mono', monospace;
font-size: 0.7rem;
color: var(--ink-muted);
text-transform: uppercase;
letter-spacing: 0.15em;
margin-bottom: 2rem;
}
.blog-breadcrumb a {
transition: color 0.2s;
}
.blog-breadcrumb a:hover {
color: var(--accent);
}
.blog-breadcrumb .sep {
color: var(--ink-muted);
}
.blog-header-title {
font-family: 'Fraunces', serif;
font-weight: 300;
font-size: clamp(3rem, 7vw, 6rem);
line-height: 0.95;
letter-spacing: -0.04em;
color: var(--ink);
margin-bottom: 1.5rem;
}
.blog-header-title .italic {
font-style: italic;
color: var(--accent);
}
.blog-header-desc {
font-family: 'Fraunces', serif;
font-style: italic;
font-size: clamp(1.1rem, 1.6vw, 1.3rem);
color: var(--ink-soft);
max-width: 60ch;
line-height: 1.5;
}
.blog-header-meta {
display: flex;
gap: 2rem;
margin-top: 3rem;
padding-top: 2rem;
border-top: 1px solid var(--line);
align-items: center;
flex-wrap: wrap;
}
.blog-header-stat {
font-family: 'JetBrains Mono', monospace;
font-size: 0.75rem;
color: var(--ink-muted);
text-transform: uppercase;
letter-spacing: 0.15em;
}
.blog-header-stat strong {
color: var(--ink);
font-weight: 500;
}
.posts-section {
padding: 5rem 3rem;
}
.posts-grid {
max-width: 1200px;
margin: 0 auto;
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 2rem;
}
.post-card {
background: var(--paper);
border: 1px solid var(--line);
border-radius: 4px;
overflow: hidden;
transition: all 0.4s cubic-bezier(0.22, 1, 0.36, 1);
display: flex;
flex-direction: column;
}
.post-card:hover {
transform: translateY(-6px);
border-color: var(--ink);
box-shadow: 0 20px 40px -15px rgba(26, 23, 20, 0.15);
}
.post-card-link {
display: flex;
flex-direction: column;
height: 100%;
}
.post-card-image {
aspect-ratio: 16 / 10;
overflow: hidden;
border-bottom: 1px solid var(--line);
position: relative;
display: flex;
align-items: center;
justify-content: center;
}
.post-card-image.pattern-1 {
background:
radial-gradient(circle at 20% 30%, rgba(196, 66, 42, 0.12), transparent 50%),
radial-gradient(circle at 80% 70%, rgba(74, 124, 89, 0.08), transparent 50%),
linear-gradient(135deg, var(--bg-alt) 0%, var(--paper) 100%);
}
.post-card-image.pattern-2 {
background:
radial-gradient(circle at 70% 30%, rgba(196, 66, 42, 0.15), transparent 50%),
radial-gradient(circle at 30% 70%, rgba(196, 66, 42, 0.05), transparent 50%),
linear-gradient(180deg, var(--paper) 0%, var(--bg-alt) 100%);
}
.post-card-image.pattern-3 {
background:
radial-gradient(circle at 50% 50%, rgba(74, 124, 89, 0.1), transparent 60%),
linear-gradient(45deg, var(--bg-alt) 0%, var(--paper) 50%, var(--bg-alt) 100%);
}
.post-card-image.pattern-4 {
background:
radial-gradient(circle at 30% 80%, rgba(196, 66, 42, 0.18), transparent 50%),
linear-gradient(135deg, var(--paper) 0%, var(--bg-alt) 100%);
}
.post-card-image.pattern-5 {
background:
radial-gradient(circle at 60% 20%, rgba(74, 124, 89, 0.15), transparent 50%),
radial-gradient(circle at 20% 80%, rgba(196, 66, 42, 0.08), transparent 50%),
linear-gradient(135deg, var(--bg-alt) 0%, var(--paper) 50%, var(--bg-alt) 100%);
}
.post-card-image.pattern-6 {
background:
radial-gradient(circle at 50% 30%, rgba(196, 66, 42, 0.1), transparent 60%),
linear-gradient(180deg, var(--bg-alt) 0%, var(--paper) 100%);
}
.post-card-letter {
font-family: 'Fraunces', serif;
font-style: italic;
font-weight: 300;
font-size: 7rem;
color: var(--accent);
line-height: 1;
transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}
.post-card:hover .post-card-letter {
transform: scale(1.08) rotate(-2deg);
}
.post-card-body {
padding: 1.8rem;
flex: 1;
display: flex;
flex-direction: column;
}
.post-card-meta {
display: flex;
gap: 1rem;
align-items: center;
margin-bottom: 1rem;
font-family: 'JetBrains Mono', monospace;
font-size: 0.7rem;
color: var(--ink-muted);
text-transform: uppercase;
letter-spacing: 0.1em;
}
.post-card-readtime {
position: relative;
padding-left: 1rem;
}
.post-card-readtime::before {
content: '·';
position: absolute;
left: 0;
}
.post-card-title {
font-family: 'Fraunces', serif;
font-size: 1.4rem;
font-weight: 400;
line-height: 1.25;
letter-spacing: -0.02em;
color: var(--ink);
margin-bottom: 0.8rem;
transition: color 0.3s ease;
}
.post-card:hover .post-card-title {
color: var(--accent);
}
.post-card-excerpt {
font-size: 0.92rem;
color: var(--ink-soft);
line-height: 1.65;
margin-bottom: 1.5rem;
flex: 1;
}
.post-card-cta {
font-family: 'JetBrains Mono', monospace;
font-size: 0.72rem;
text-transform: uppercase;
letter-spacing: 0.15em;
color: var(--accent);
font-weight: 500;
display: inline-flex;
align-items: center;
gap: 0.5rem;
margin-top: auto;
}
.post-card-cta .arrow {
transition: transform 0.3s;
display: inline-block;
}
.post-card:hover .post-card-cta .arrow {
transform: translateX(4px);
} .pagination {
max-width: 1200px;
margin: 4rem auto 0;
display: flex;
justify-content: center;
align-items: center;
gap: 0.5rem;
flex-wrap: wrap;
}
.page-link {
min-width: 42px;
height: 42px;
display: inline-flex;
align-items: center;
justify-content: center;
padding: 0 0.8rem;
border: 1px solid var(--line-strong);
border-radius: 100px;
font-family: 'JetBrains Mono', monospace;
font-size: 0.8rem;
color: var(--ink-soft);
transition: all 0.25s ease;
text-decoration: none;
}
.page-link:hover {
border-color: var(--ink);
color: var(--ink);
}
.page-link.active,
.page-link.current {
background: var(--ink);
color: var(--bg);
border-color: var(--ink);
}
.page-link.dots {
border: none;
cursor: default;
} .posts-empty {
max-width: 600px;
margin: 0 auto;
text-align: center;
padding: 4rem 2rem;
color: var(--ink-soft);
font-size: 1.1rem;
} @media (max-width: 900px) {
.blog-header {
padding: 7rem 1.5rem 3rem;
}
.posts-section {
padding: 3rem 1.5rem;
}
.posts-grid {
grid-template-columns: 1fr;
gap: 1.5rem;
}
}  .progress-bar {
position: fixed;
top: 0;
left: 0;
height: 3px;
background: var(--accent);
z-index: 200;
width: 0;
transition: width 0.1s ease;
} .article-header {
padding: 9rem 3rem 4rem;
background: var(--paper);
border-bottom: 1px solid var(--line);
text-align: center;
}
.article-header-inner {
max-width: 800px;
margin: 0 auto;
}
.breadcrumb {
display: flex;
align-items: center;
justify-content: center;
gap: 0.6rem;
font-family: 'JetBrains Mono', monospace;
font-size: 0.7rem;
color: var(--ink-muted);
text-transform: uppercase;
letter-spacing: 0.15em;
margin-bottom: 2rem;
}
.breadcrumb a {
transition: color 0.2s;
text-decoration: none;
color: var(--ink-muted);
}
.breadcrumb a:hover {
color: var(--accent);
}
.article-category {
display: inline-block;
background: var(--accent-bg);
color: var(--accent);
padding: 0.4rem 1rem;
border-radius: 100px;
font-family: 'JetBrains Mono', monospace;
font-size: 0.7rem;
text-transform: uppercase;
letter-spacing: 0.15em;
font-weight: 500;
margin-bottom: 1.5rem;
}
.article-title {
font-family: 'Fraunces', serif;
font-weight: 300;
font-size: clamp(2.2rem, 5.5vw, 4.5rem);
line-height: 1.05;
letter-spacing: -0.03em;
color: var(--ink);
margin-bottom: 1.5rem;
max-width: 22ch;
margin-left: auto;
margin-right: auto;
}
.article-title .italic {
font-style: italic;
color: var(--accent);
}
.article-subtitle {
font-family: 'Fraunces', serif;
font-style: italic;
font-size: clamp(1.1rem, 1.5vw, 1.3rem);
color: var(--ink-soft);
max-width: 50ch;
margin: 0 auto 2.5rem;
line-height: 1.5;
}
.article-meta {
display: flex;
justify-content: center;
align-items: center;
gap: 2rem;
padding-top: 2rem;
border-top: 1px solid var(--line);
flex-wrap: wrap;
}
.meta-block {
display: flex;
flex-direction: column;
gap: 0.3rem;
text-align: left;
}
.meta-block-label {
font-family: 'JetBrains Mono', monospace;
font-size: 0.65rem;
color: var(--ink-muted);
text-transform: uppercase;
letter-spacing: 0.15em;
}
.meta-block-value {
font-size: 0.9rem;
color: var(--ink);
font-weight: 500;
}
.meta-author {
display: flex;
align-items: center;
gap: 0.8rem;
}
.author-avatar {
width: 40px;
height: 40px;
border-radius: 50%;
background: linear-gradient(135deg, var(--accent), #8b2f1a);
display: flex;
align-items: center;
justify-content: center;
color: var(--paper);
font-family: 'Fraunces', serif;
font-style: italic;
font-size: 1.1rem;
} .author-avatar-img {
width: 40px !important;
height: 40px !important;
border-radius: 50%;
object-fit: cover;
}
.author-box-avatar-img {
width: 72px !important;
height: 72px !important;
border-radius: 50%;
object-fit: cover;
flex-shrink: 0;
} .article-cover {
max-width: 1100px;
margin: 0 auto;
padding: 0 3rem;
margin-top: -3rem;
position: relative;
z-index: 10;
}
.article-cover-inner {
aspect-ratio: 21 / 9;
background:
radial-gradient(circle at 30% 30%, rgba(196, 66, 42, 0.15), transparent 50%),
radial-gradient(circle at 70% 70%, rgba(74, 124, 89, 0.1), transparent 50%),
linear-gradient(135deg, var(--bg-alt) 0%, var(--paper) 100%);
border-radius: 8px;
border: 1px solid var(--line);
display: flex;
align-items: center;
justify-content: center;
overflow: hidden;
}
.article-cover-letter {
font-family: 'Fraunces', serif;
font-style: italic;
font-weight: 300;
font-size: clamp(8rem, 20vw, 16rem);
color: var(--accent);
line-height: 1;
opacity: 0.9;
}
.article-cover-inner img {
width: 100%;
height: 100%;
object-fit: cover;
display: block;
} .article-body {
max-width: 720px;
margin: 0 auto;
padding: 5rem 3rem;
font-family: 'Fraunces', serif;
font-size: 1.15rem;
line-height: 1.75;
color: var(--ink-soft);
}
.article-body p {
margin-bottom: 1.5rem;
}
.article-body h2 {
font-family: 'Fraunces', serif;
font-size: clamp(1.7rem, 3vw, 2.2rem);
font-weight: 400;
color: var(--ink);
line-height: 1.2;
letter-spacing: -0.02em;
margin-top: 3.5rem;
margin-bottom: 1.2rem;
}
.article-body h3 {
font-family: 'Fraunces', serif;
font-size: 1.35rem;
font-weight: 500;
color: var(--ink);
margin-top: 2.5rem;
margin-bottom: 0.8rem;
letter-spacing: -0.01em;
}
.article-body strong {
color: var(--ink);
font-weight: 600;
}
.article-body em {
font-style: italic;
color: var(--accent);
}
.article-body a {
color: var(--accent);
text-decoration: underline;
text-decoration-thickness: 1px;
text-underline-offset: 3px;
transition: color 0.2s;
}
.article-body a:hover {
color: var(--ink);
}
.article-body ul,
.article-body ol {
margin: 1.5rem 0 1.5rem 1.5rem;
}
.article-body li {
margin-bottom: 0.6rem;
padding-left: 0.5rem;
}
.article-body ul li::marker {
color: var(--accent);
}
.article-body blockquote {
border-left: 3px solid var(--accent);
padding: 1rem 1.5rem;
margin: 2.5rem 0;
font-style: italic;
color: var(--ink);
background: var(--accent-bg);
border-radius: 0 4px 4px 0;
font-size: 1.2rem;
}
.article-body code {
font-family: 'JetBrains Mono', monospace;
background: var(--bg-alt);
color: var(--accent);
padding: 0.15em 0.4em;
border-radius: 3px;
font-size: 0.9em;
}
.article-body pre {
background: var(--ink);
color: var(--paper);
padding: 1.5rem;
border-radius: 6px;
overflow-x: auto;
margin: 2rem 0;
font-family: 'JetBrains Mono', monospace;
font-size: 0.85rem;
line-height: 1.6;
}
.article-body pre code {
background: transparent;
color: var(--paper);
padding: 0;
font-size: inherit;
}
.article-body img {
max-width: 100%;
height: auto;
border-radius: 6px;
margin: 2rem 0;
border: 1px solid var(--line);
}
.article-body hr {
border: none;
height: 1px;
background: var(--line);
margin: 3rem 0;
} .article-tags {
max-width: 720px;
margin: 0 auto;
padding: 0 3rem;
display: flex;
align-items: center;
gap: 0.6rem;
flex-wrap: wrap;
padding-bottom: 3rem;
border-bottom: 1px solid var(--line);
margin-bottom: 3rem;
}
.tags-label {
font-family: 'JetBrains Mono', monospace;
font-size: 0.7rem;
color: var(--ink-muted);
text-transform: uppercase;
letter-spacing: 0.15em;
margin-right: 0.5rem;
}
.tag {
font-family: 'JetBrains Mono', monospace;
font-size: 0.75rem;
padding: 0.35rem 0.8rem;
border: 1px solid var(--line-strong);
border-radius: 100px;
color: var(--ink-soft);
transition: all 0.25s;
text-decoration: none;
}
.tag:hover {
background: var(--ink);
color: var(--bg);
border-color: var(--ink);
} .share-bar {
max-width: 720px;
margin: 0 auto;
padding: 0 3rem 3rem;
display: flex;
align-items: center;
gap: 1rem;
flex-wrap: wrap;
}
.share-label {
font-family: 'JetBrains Mono', monospace;
font-size: 0.7rem;
color: var(--ink-muted);
text-transform: uppercase;
letter-spacing: 0.15em;
}
.share-btn {
display: inline-flex;
align-items: center;
gap: 0.5rem;
padding: 0.55rem 1rem;
border: 1px solid var(--line-strong);
border-radius: 100px;
font-size: 0.8rem;
color: var(--ink-soft);
cursor: pointer;
transition: all 0.25s;
background: transparent;
font-family: inherit;
text-decoration: none;
}
.share-btn:hover {
background: var(--ink);
color: var(--bg);
border-color: var(--ink);
} .author-box {
max-width: 720px;
margin: 0 auto 5rem;
padding: 2.5rem 3rem;
background: var(--paper);
border: 1px solid var(--line);
border-radius: 8px;
display: flex;
gap: 2rem;
align-items: flex-start;
}
.author-box-avatar {
width: 72px;
height: 72px;
border-radius: 50%;
background: linear-gradient(135deg, var(--accent), #8b2f1a);
display: flex;
align-items: center;
justify-content: center;
color: var(--paper);
font-family: 'Fraunces', serif;
font-style: italic;
font-size: 1.8rem;
flex-shrink: 0;
}
.author-box-info {
flex: 1;
}
.author-box-label {
font-family: 'JetBrains Mono', monospace;
font-size: 0.7rem;
color: var(--ink-muted);
text-transform: uppercase;
letter-spacing: 0.15em;
margin-bottom: 0.5rem;
}
.author-box-name {
font-family: 'Fraunces', serif;
font-size: 1.4rem;
font-weight: 400;
margin-bottom: 0.5rem;
color: var(--ink);
}
.author-box-bio {
font-size: 0.9rem;
color: var(--ink-soft);
line-height: 1.6;
margin-bottom: 1rem;
font-family: 'Inter Tight', sans-serif;
}
.author-box-cta {
display: inline-flex;
align-items: center;
gap: 0.5rem;
color: var(--accent);
font-family: 'JetBrains Mono', monospace;
font-size: 0.75rem;
text-transform: uppercase;
letter-spacing: 0.15em;
font-weight: 500;
text-decoration: none;
}
.author-box-cta .arrow {
transition: transform 0.3s;
}
.author-box-cta:hover .arrow {
transform: translateX(4px);
} .related-section {
background: var(--paper);
border-top: 1px solid var(--line);
padding: 5rem 3rem;
}
.related-inner {
max-width: 1200px;
margin: 0 auto;
}
.related-header {
display: flex;
justify-content: space-between;
align-items: baseline;
margin-bottom: 3rem;
border-bottom: 1px solid var(--line);
padding-bottom: 1.5rem;
}
.related-title {
font-family: 'Fraunces', serif;
font-size: clamp(1.8rem, 3vw, 2.4rem);
font-weight: 300;
letter-spacing: -0.02em;
}
.related-title .italic {
font-style: italic;
color: var(--accent);
}
.related-link {
font-family: 'JetBrains Mono', monospace;
font-size: 0.75rem;
color: var(--ink-muted);
text-transform: uppercase;
letter-spacing: 0.15em;
transition: color 0.2s;
text-decoration: none;
}
.related-link:hover {
color: var(--accent);
}
.related-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 2rem;
}
.related-card {
background: var(--bg);
border: 1px solid var(--line);
border-radius: 4px;
overflow: hidden;
transition: all 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}
.related-card:hover {
transform: translateY(-4px);
border-color: var(--ink);
box-shadow: 0 16px 32px -12px rgba(26, 23, 20, 0.12);
}
.related-card a {
text-decoration: none;
color: inherit;
display: block;
}
.related-card-image {
aspect-ratio: 16 / 10;
display: flex;
align-items: center;
justify-content: center;
border-bottom: 1px solid var(--line);
}
.related-card-image.r1 {
background: radial-gradient(circle at 30% 30%, rgba(196, 66, 42, 0.12), transparent 50%),
linear-gradient(135deg, var(--bg-alt), var(--paper));
}
.related-card-image.r2 {
background: radial-gradient(circle at 70% 50%, rgba(74, 124, 89, 0.1), transparent 50%),
linear-gradient(180deg, var(--paper), var(--bg-alt));
}
.related-card-image.r3 {
background: radial-gradient(circle at 50% 50%, rgba(196, 66, 42, 0.1), transparent 60%),
linear-gradient(45deg, var(--bg-alt), var(--paper), var(--bg-alt));
}
.related-card-letter {
font-family: 'Fraunces', serif;
font-style: italic;
font-size: 4rem;
color: var(--accent);
line-height: 1;
}
.related-card-body {
padding: 1.4rem;
}
.related-card-meta {
font-family: 'JetBrains Mono', monospace;
font-size: 0.65rem;
color: var(--ink-muted);
text-transform: uppercase;
letter-spacing: 0.15em;
margin-bottom: 0.6rem;
}
.related-card-title {
font-family: 'Fraunces', serif;
font-size: 1.15rem;
font-weight: 400;
line-height: 1.3;
color: var(--ink);
transition: color 0.3s;
}
.related-card:hover .related-card-title {
color: var(--accent);
} .cta-section {
background: var(--ink);
color: var(--bg);
padding: 6rem 3rem;
text-align: center;
}
.cta-title {
font-family: 'Fraunces', serif;
font-size: clamp(2rem, 4vw, 3rem);
font-weight: 300;
line-height: 1.1;
letter-spacing: -0.03em;
margin-bottom: 1rem;
max-width: 22ch;
margin-left: auto;
margin-right: auto;
}
.cta-title .italic {
font-style: italic;
color: var(--accent-soft);
}
.cta-desc {
color: rgba(245, 241, 234, 0.7);
margin-bottom: 2rem;
font-family: 'Fraunces', serif;
font-style: italic;
font-size: 1.1rem;
}
.cta-btn {
display: inline-flex;
align-items: center;
gap: 0.6rem;
background: var(--accent);
color: var(--bg);
padding: 0.85rem 1.8rem;
border-radius: 100px;
font-size: 0.9rem;
font-weight: 500;
transition: all 0.3s cubic-bezier(0.22, 1, 0.36, 1);
text-decoration: none;
}
.cta-btn:hover {
background: var(--bg);
color: var(--ink);
transform: translateY(-2px);
}
.cta-btn .arrow {
transition: transform 0.3s;
}
.cta-btn:hover .arrow {
transform: translateX(4px);
} @media (max-width: 900px) {
.article-header {
padding: 7rem 1.5rem 3rem;
}
.article-cover {
padding: 0 1.5rem;
}
.article-body {
padding: 4rem 1.5rem;
font-size: 1.05rem;
}
.article-tags {
padding: 0 1.5rem 2rem;
}
.share-bar {
padding: 0 1.5rem 2rem;
}
.author-box {
padding: 2rem 1.5rem;
flex-direction: column;
gap: 1.2rem;
margin: 0 1.5rem 4rem;
}
.related-section {
padding: 4rem 1.5rem;
}
.related-grid {
grid-template-columns: 1fr;
gap: 1.5rem;
}
.related-header {
flex-direction: column;
align-items: flex-start;
gap: 1rem;
}
.cta-section {
padding: 4rem 1.5rem;
}
.article-meta {
gap: 1rem;
}
} .whatsapp-btn {
position: fixed;
bottom: 2rem;
right: 2rem;
z-index: 999;
display: inline-flex;
align-items: center;
gap: 0.6rem;
background: #25D366;
color: #fff;
padding: 0.85rem;
border-radius: 100px;
text-decoration: none;
font-family: 'Inter Tight', sans-serif;
font-size: 0.9rem;
font-weight: 500;
box-shadow: 0 4px 20px rgba(37, 211, 102, 0.4);
transition: all 0.3s cubic-bezier(0.22, 1, 0.36, 1);
border: none;
cursor: pointer;
}
.whatsapp-btn:hover {
background: #128C7E;
transform: translateY(-3px) scale(1.03);
box-shadow: 0 8px 30px rgba(37, 211, 102, 0.5);
color: #fff;
}
.whatsapp-btn svg {
width: 22px;
height: 22px;
flex-shrink: 0;
fill: #fff;
}
.whatsapp-btn-text {
white-space: nowrap;
display: none;
} @media (max-width: 600px) {
.whatsapp-btn {
padding: 0.85rem;
border-radius: 50%;
bottom: 1.5rem;
right: 1.5rem;
box-shadow: 0 4px 20px rgba(37, 211, 102, 0.5);
}
.whatsapp-btn-text {
display: none;
}
.whatsapp-btn svg {
width: 26px;
height: 26px;
}
} .admin-bar .whatsapp-btn {
bottom: 2rem;
}  .page-header {
padding: 9rem 3rem 5rem;
background: var(--paper);
border-bottom: 1px solid var(--line);
text-align: center;
}
.page-header-inner {
max-width: 800px;
margin: 0 auto;
}
.breadcrumb {
display: inline-flex;
align-items: center;
gap: 0.6rem;
font-family: 'JetBrains Mono', monospace;
font-size: 0.7rem;
color: var(--ink-muted);
text-transform: uppercase;
letter-spacing: 0.15em;
margin-bottom: 2rem;
}
.breadcrumb a {
transition: color 0.2s;
text-decoration: none;
color: var(--ink-muted);
}
.breadcrumb a:hover {
color: var(--accent);
}
.page-status {
display: inline-flex;
align-items: center;
gap: 0.6rem;
background: rgba(74, 124, 89, 0.1);
color: var(--green);
padding: 0.5rem 1rem;
border-radius: 100px;
font-family: 'JetBrains Mono', monospace;
font-size: 0.75rem;
font-weight: 500;
border: 1px solid rgba(74, 124, 89, 0.2);
margin-bottom: 2rem;
}
.page-status .dot {
width: 8px;
height: 8px;
border-radius: 50%;
background: var(--green);
animation: pulse 2s ease-in-out infinite;
}
.page-title {
font-family: 'Fraunces', serif;
font-weight: 300;
font-size: clamp(2.5rem, 6vw, 5rem);
line-height: 1.05;
letter-spacing: -0.04em;
color: var(--ink);
margin-bottom: 1.5rem;
}
.page-title .italic {
font-style: italic;
color: var(--accent);
}
.page-subtitle {
font-family: 'Fraunces', serif;
font-style: italic;
font-size: clamp(1.1rem, 1.5vw, 1.3rem);
color: var(--ink-soft);
max-width: 55ch;
margin: 0 auto;
line-height: 1.5;
} .trust-bar {
background: var(--ink);
color: var(--bg);
padding: 2rem 3rem;
display: flex;
justify-content: center;
align-items: center;
gap: 4rem;
flex-wrap: wrap;
}
.trust-item {
display: flex;
flex-direction: column;
align-items: center;
text-align: center;
gap: 0.3rem;
}
.trust-num {
font-family: 'Fraunces', serif;
font-size: 2rem;
font-weight: 300;
color: var(--accent-soft);
font-style: italic;
line-height: 1;
}
.trust-label {
font-family: 'JetBrains Mono', monospace;
font-size: 0.7rem;
color: rgba(245, 241, 234, 0.6);
text-transform: uppercase;
letter-spacing: 0.15em;
} .pricing {
padding: 6rem 3rem;
}
.pricing .section-header {
max-width: 1200px;
margin: 0 auto 4rem;
text-align: center;
display: block;
grid-template-columns: unset;
}
.section-desc {
font-family: 'Fraunces', serif;
font-style: italic;
font-size: 1.15rem;
color: var(--ink-soft);
max-width: 50ch;
margin: 1.2rem auto 0;
line-height: 1.5;
}
.pricing-grid {
max-width: 1200px;
margin: 0 auto;
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 2rem;
}
.pricing-card {
background: var(--paper);
border: 1px solid var(--line);
border-radius: 6px;
padding: 2.5rem;
display: flex;
flex-direction: column;
position: relative;
transition: all 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}
.pricing-card:hover {
transform: translateY(-6px);
border-color: var(--ink);
box-shadow: 0 20px 40px -15px rgba(26, 23, 20, 0.15);
}
.pricing-card.featured {
background: var(--ink);
color: var(--bg);
border-color: var(--ink);
transform: scale(1.03);
}
.pricing-card.featured:hover {
transform: scale(1.03) translateY(-6px);
}
.pricing-badge {
position: absolute;
top: -12px;
left: 50%;
transform: translateX(-50%);
background: var(--accent);
color: var(--bg);
padding: 0.3rem 0.9rem;
border-radius: 100px;
font-family: 'JetBrains Mono', monospace;
font-size: 0.65rem;
text-transform: uppercase;
letter-spacing: 0.15em;
font-weight: 500;
white-space: nowrap;
}
.pricing-tag {
font-family: 'JetBrains Mono', monospace;
font-size: 0.7rem;
text-transform: uppercase;
letter-spacing: 0.15em;
color: var(--ink-muted);
margin-bottom: 0.8rem;
}
.pricing-card.featured .pricing-tag {
color: rgba(245, 241, 234, 0.5);
}
.pricing-name {
font-family: 'Fraunces', serif;
font-size: 2rem;
font-weight: 400;
line-height: 1;
letter-spacing: -0.02em;
margin-bottom: 0.5rem;
}
.pricing-name .italic {
font-style: italic;
color: var(--accent);
}
.pricing-card.featured .pricing-name .italic {
color: var(--accent-soft);
}
.pricing-tagline {
font-family: 'Fraunces', serif;
font-style: italic;
font-size: 0.95rem;
color: var(--ink-muted);
line-height: 1.4;
margin-bottom: 2rem;
min-height: 2.5em;
}
.pricing-card.featured .pricing-tagline {
color: rgba(245, 241, 234, 0.6);
}
.pricing-price {
margin-bottom: 2rem;
padding-bottom: 2rem;
border-bottom: 1px solid var(--line);
}
.pricing-card.featured .pricing-price {
border-bottom-color: rgba(245, 241, 234, 0.15);
}
.pricing-price-from {
font-family: 'JetBrains Mono', monospace;
font-size: 0.7rem;
text-transform: uppercase;
letter-spacing: 0.15em;
color: var(--ink-muted);
margin-bottom: 0.3rem;
}
.pricing-card.featured .pricing-price-from {
color: rgba(245, 241, 234, 0.5);
}
.pricing-price-amount {
font-family: 'Fraunces', serif;
font-size: 2.8rem;
font-weight: 300;
letter-spacing: -0.03em;
line-height: 1;
color: var(--ink);
}
.pricing-card.featured .pricing-price-amount {
color: var(--bg);
}
.pricing-price-amount .currency {
font-size: 1.5rem;
color: var(--accent);
}
.pricing-card.featured .pricing-price-amount .currency {
color: var(--accent-soft);
}
.pricing-price-amount .unit {
font-family: 'Inter Tight', sans-serif;
font-size: 0.9rem;
color: var(--ink-muted);
font-style: normal;
margin-left: 0.5rem;
font-weight: 400;
}
.pricing-card.featured .pricing-price-amount .unit {
color: rgba(245, 241, 234, 0.5);
}
.pricing-features {
list-style: none;
margin-bottom: 2rem;
flex: 1;
}
.pricing-features li {
padding: 0.6rem 0;
padding-left: 1.8rem;
position: relative;
font-size: 0.92rem;
line-height: 1.5;
color: var(--ink-soft);
border-bottom: 1px solid var(--line);
}
.pricing-features li:last-child {
border-bottom: none;
}
.pricing-card.featured .pricing-features li {
color: rgba(245, 241, 234, 0.85);
border-bottom-color: rgba(245, 241, 234, 0.1);
}
.pricing-features li::before {
content: '✓';
position: absolute;
left: 0;
top: 0.6rem;
color: var(--accent);
font-weight: 600;
}
.pricing-card.featured .pricing-features li::before {
color: var(--accent-soft);
}
.pricing-cta {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 0.5rem;
width: 100%;
padding: 0.95rem 1.5rem;
background: var(--ink);
color: var(--bg);
border-radius: 100px;
font-size: 0.9rem;
font-weight: 500;
transition: all 0.3s cubic-bezier(0.22, 1, 0.36, 1);
border: 1px solid var(--ink);
text-decoration: none;
margin-top: auto;
}
.pricing-card.featured .pricing-cta {
background: var(--accent);
border-color: var(--accent);
}
.pricing-cta:hover {
background: var(--accent);
border-color: var(--accent);
transform: translateY(-2px);
box-shadow: 0 10px 25px -8px rgba(196, 66, 42, 0.4);
color: var(--bg);
}
.pricing-card.featured .pricing-cta:hover {
background: var(--bg);
color: var(--ink);
border-color: var(--bg);
}
.pricing-cta .arrow {
transition: transform 0.3s;
display: inline-block;
}
.pricing-cta:hover .arrow {
transform: translateX(4px);
} .services {
padding: 6rem 3rem;
background: var(--paper);
border-top: 1px solid var(--line);
border-bottom: 1px solid var(--line);
}
.services-grid {
max-width: 1200px;
margin: 0 auto;
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 1.5rem;
}
.service-card {
background: var(--bg);
border: 1px solid var(--line);
border-radius: 6px;
padding: 2rem;
display: flex;
flex-direction: column;
gap: 1rem;
transition: all 0.3s ease;
}
.service-card:hover {
border-color: var(--ink);
transform: translateY(-3px);
}
.service-header {
display: flex;
justify-content: space-between;
align-items: flex-start;
gap: 1rem;
}
.service-name {
font-family: 'Fraunces', serif;
font-size: 1.4rem;
font-weight: 400;
line-height: 1.2;
letter-spacing: -0.02em;
color: var(--ink);
}
.service-name .italic {
font-style: italic;
color: var(--accent);
}
.service-price {
font-family: 'Fraunces', serif;
font-size: 1.1rem;
color: var(--accent);
white-space: nowrap;
text-align: right;
}
.service-price small {
display: block;
font-family: 'JetBrains Mono', monospace;
font-size: 0.65rem;
color: var(--ink-muted);
text-transform: uppercase;
letter-spacing: 0.1em;
font-style: normal;
margin-top: 0.2rem;
}
.service-desc {
font-size: 0.9rem;
color: var(--ink-soft);
line-height: 1.6;
}
.service-meta {
display: flex;
gap: 1.2rem;
padding-top: 1rem;
border-top: 1px solid var(--line);
font-family: 'JetBrains Mono', monospace;
font-size: 0.7rem;
color: var(--ink-muted);
text-transform: uppercase;
letter-spacing: 0.1em;
}
.service-meta-item {
display: flex;
align-items: center;
gap: 0.4rem;
}
.service-meta-item strong {
color: var(--ink);
font-weight: 500;
} .process {
padding: 6rem 3rem;
}
.process-steps {
max-width: 900px;
margin: 0 auto;
display: grid;
grid-template-columns: repeat(4, 1fr);
gap: 1rem;
position: relative;
}
.process-steps::before {
content: '';
position: absolute;
top: 24px;
left: 12.5%;
right: 12.5%;
height: 1px;
background: var(--line);
z-index: 0;
}
.process-step {
text-align: center;
position: relative;
z-index: 1;
}
.process-step-num {
width: 48px;
height: 48px;
border-radius: 50%;
background: var(--bg);
border: 1px solid var(--line-strong);
display: flex;
align-items: center;
justify-content: center;
margin: 0 auto 1.2rem;
font-family: 'Fraunces', serif;
font-style: italic;
font-size: 1.1rem;
font-weight: 400;
color: var(--ink);
transition: all 0.3s;
}
.process-step:hover .process-step-num {
background: var(--accent);
border-color: var(--accent);
color: var(--bg);
transform: scale(1.1);
}
.process-step-title {
font-family: 'Fraunces', serif;
font-size: 1.1rem;
font-weight: 500;
margin-bottom: 0.5rem;
color: var(--ink);
}
.process-step-desc {
font-size: 0.85rem;
color: var(--ink-soft);
line-height: 1.5;
} .faq {
padding: 6rem 3rem;
background: var(--paper);
border-top: 1px solid var(--line);
}
.faq-list {
max-width: 800px;
margin: 0 auto;
}
.faq-item {
border-bottom: 1px solid var(--line);
padding: 1.5rem 0;
}
.faq-item:first-child {
border-top: 1px solid var(--line);
}
.faq-question {
width: 100%;
background: none;
border: none;
font-family: 'Fraunces', serif;
font-size: 1.2rem;
font-weight: 400;
color: var(--ink);
cursor: pointer;
text-align: left;
display: flex;
justify-content: space-between;
align-items: center;
gap: 1rem;
line-height: 1.4;
transition: color 0.2s;
padding: 0.5rem 0;
}
.faq-question:hover {
color: var(--accent);
}
.faq-icon {
font-family: 'Fraunces', serif;
font-size: 1.5rem;
font-weight: 300;
color: var(--accent);
transition: transform 0.3s ease;
flex-shrink: 0;
}
.faq-item.open .faq-icon {
transform: rotate(45deg);
}
.faq-answer {
max-height: 0;
overflow: hidden;
transition: max-height 0.4s ease, padding-top 0.3s ease;
color: var(--ink-soft);
font-size: 1rem;
line-height: 1.7;
}
.faq-item.open .faq-answer {
max-height: 500px;
padding-top: 1rem;
} .cta-section {
background: var(--ink);
color: var(--bg);
padding: 6rem 3rem;
text-align: center;
}
.cta-title {
font-family: 'Fraunces', serif;
font-size: clamp(2.5rem, 5vw, 4.5rem);
font-weight: 300;
line-height: 1;
letter-spacing: -0.04em;
margin-bottom: 1.5rem;
max-width: 18ch;
margin-left: auto;
margin-right: auto;
}
.cta-title .italic {
font-style: italic;
color: var(--accent-soft);
}
.cta-desc {
color: rgba(245, 241, 234, 0.7);
margin-bottom: 2.5rem;
font-family: 'Fraunces', serif;
font-style: italic;
font-size: 1.15rem;
max-width: 50ch;
margin-left: auto;
margin-right: auto;
}
.cta-buttons {
display: flex;
gap: 0.8rem;
justify-content: center;
flex-wrap: wrap;
}
.cta-btn {
display: inline-flex;
align-items: center;
gap: 0.6rem;
padding: 0.85rem 1.8rem;
border-radius: 100px;
font-size: 0.9rem;
font-weight: 500;
transition: all 0.3s cubic-bezier(0.22, 1, 0.36, 1);
border: 1px solid transparent;
text-decoration: none;
}
.cta-btn.primary {
background: var(--accent);
color: var(--bg);
}
.cta-btn.primary:hover {
background: var(--bg);
color: var(--ink);
transform: translateY(-2px);
}
.cta-btn.secondary {
background: transparent;
color: var(--bg);
border-color: rgba(245, 241, 234, 0.3);
}
.cta-btn.secondary:hover {
border-color: var(--bg);
transform: translateY(-2px);
}
.cta-btn .arrow {
transition: transform 0.3s;
}
.cta-btn:hover .arrow {
transform: translateX(4px);
} @media (max-width: 900px) {
.page-header {
padding: 7rem 1.5rem 3rem;
}
.trust-bar {
gap: 2rem;
padding: 2rem 1.5rem;
}
.pricing {
padding: 4rem 1.5rem;
}
.pricing-grid {
grid-template-columns: 1fr;
gap: 1.5rem;
}
.pricing-card.featured {
transform: none;
}
.pricing-card.featured:hover {
transform: translateY(-6px);
}
.services {
padding: 4rem 1.5rem;
}
.services-grid {
grid-template-columns: 1fr;
}
.process {
padding: 4rem 1.5rem;
}
.process-steps {
grid-template-columns: 1fr;
gap: 2rem;
}
.process-steps::before {
display: none;
}
.faq {
padding: 4rem 1.5rem;
}
.cta-section {
padding: 4rem 1.5rem;
}
}
.services .section-header,
.pricing .section-header,
.process .section-header,
.faq .section-header {
display: block !important;
grid-template-columns: unset !important;
text-align: center;
}