/* Reset and Base Styles */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
    background-color: #F3F3F3;
    color: #333333;
    line-height: 1.7;
}

/* Scroll reveal */
.reveal {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 700ms ease, transform 700ms ease;
  will-change: opacity, transform;
}

.reveal.reveal-slow {
  transition: opacity 1100ms ease, transform 1100ms ease;
}

.reveal.reveal-slower {
  transition: opacity 1600ms ease, transform 1600ms ease;
}

.reveal.reveal-video {
  transition: opacity 1400ms ease, transform 1400ms ease;
}

.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
  .reveal {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* Global link hover animation */
a {
    display: inline-block;
    transition: transform 320ms cubic-bezier(0.22, 1, 0.36, 1), color 240ms ease, background-color 240ms ease, opacity 240ms ease;
}

a:hover {
    transform: translateY(-2px);
}

a:active {
    transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
    a {
        transition: color 240ms ease, background-color 240ms ease, opacity 240ms ease;
    }

    a:hover,
    a:active {
        transform: none;
    }
}

.container {
    max-width: 1120px;
    margin: 0 auto;
    padding: 0 32px;
}

/* Hero Section */
.hero {
    position: relative;
    width: 100%;
    height: clamp(500px, 80vh, 900px);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.hero-video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 0;
    opacity: 0;
    transition: opacity 1400ms ease;
}

.hero-video.is-ready {
    opacity: 1;
}

.hero-intro {
    opacity: 0;
    transform: translateY(16px);
    transition: opacity 1400ms ease, transform 1400ms ease;
    will-change: opacity, transform;
}

body.hero-ready .hero-intro {
    opacity: 1;
    transform: translateY(0);
}

.logo-badge {
    position: absolute;
    top: 32px;
    left: 37px;
    width: 64px;
    height: 64px;
    background-color: transparent;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    z-index: 2;
}

.logo-badge--right {
    left: auto;
    right: 28px;
}

.logo-badge img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
    /* Use the black logo asset but render it white over video */
    filter: invert(1);
}

.logo-text {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #FFFFFF;
    font-size: 14px;
    font-weight: 500;
    line-height: 1.05;
    text-align: center;
}

.logo-text span {
    display: block;
}

.hero-content {
    text-align: center;
    position: relative;
    z-index: 1;
}

.hero-content h1 {
    font-size: clamp(44px, 5vw, 52px);
    font-weight: 300;
    color: #FFFFFF;
    line-height: 1.05;
    margin-bottom: 8px;
}

.hero-subtitle {
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.22em;
    color: rgba(255, 255, 255, 0.70);
}

/* Navigation Strip */
.nav-strip {
    width: 100%;
    background-color: #F3F3F3;
    padding-top: 26px;
    padding-bottom: 26px;
}

.nav-strip .container {
    max-width: 100%;
    padding-left: 28px;
    padding-right: 56px;
    display: flex;
    align-items: center;
    gap: 24px;
}

/* Ensure logo badge is always visible inside the nav strip */
.nav-strip .header-logo-badge {
    display: flex;
}

.nav-links {
    list-style: none;
    display: flex;
    justify-content: flex-end;
    gap: 40px;
    flex-wrap: wrap;
    margin-left: auto;
    padding-right: 0;
}

.nav-links a {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: #555555;
    text-decoration: none;
    transition: color 240ms ease, transform 320ms cubic-bezier(0.22, 1, 0.36, 1);
    font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
    font-weight: 400;
}

.nav-links a:hover {
    color: #333333;
}

.nav-links a.active,
.nav-links a[aria-current="page"] {
    color: #333333;
    font-weight: 700 !important;
}

/* Statement Section */
.statement-section {
    background-color: #F3F3F3;
    padding-top: 80px;
    padding-bottom: 30px;
}

.statement-headline {
    font-size: clamp(28px, 3vw, 32px);
    font-weight: 300;
    color: #3A3A3A;
    text-align: center;
    max-width: 780px;
    margin: 0 auto;
    line-height: 1.4;
}

.statement-supporting {
    font-size: 16px;
    color: #6A6A6A;
    text-align: center;
    max-width: 680px;
    margin: 22px auto 0;
    line-height: 1.6;
    font-weight: 200;
}

/* Icon Section */
.icon-section {
    background-color: #F3F3F3;
    padding-bottom: 90px;
}

.icon-section-title {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: #333333;
    text-align: center;
    margin-top: 46px;
    margin-bottom: 40px;
}

.icon-row {
    display: flex;
    justify-content: center;
    gap: 120px;
    flex-wrap: wrap;
}

.icon-item {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.icon {
    width: 44px;
    height: 44px;
}

.icon-label {
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: #4A4A4A;
    margin-top: 14px;
    text-align: center;
}

/* Feature Blocks */
.feature-block {
    background-color: #FFFFFF;
    padding-top: 70px;
    padding-bottom: 70px;
}

.feature-content {
    display: flex;
    gap: 64px;
    align-items: center;
}

.feature-image {
    width: 48%;
    flex-shrink: 0;
}

.feature-image img {
    width: 100%;
    height: auto;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    background-color: #FFFFFF;
    display: block;
}

.feature-text {
    width: 52%;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.feature-heading {
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: #2F2F2F;
    font-weight: 500;
    margin-bottom: 18px;
}

.feature-paragraph {
    font-size: 16px;
    color: #6A6A6A;
    line-height: 1.6;
    font-weight: 200;
    max-width: 520px;
    margin-bottom: 12px;
}

.feature-paragraph:last-of-type {
    margin-bottom: 0;
}

.feature-button {
    margin-top: 22px;
    width: 140px;
    height: 38px;
    border: 1px solid #2B2B2B;
    background: transparent;
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: #2B2B2B;
    cursor: pointer;
    transition: all 0.2s;
    font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
    margin-left: auto;
    margin-right: auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
}

.feature-button:hover {
    opacity: 0.75;
}

/* Footer */
.footer {
    background-color: #282828;
    padding-top: 56px;
    padding-bottom: 48px;
    width: 100%;
}

.footer-content {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: 40px;
}

.footer-links {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.footer-links a {
    font-size: 14px;
    color: #BDBDBD;
    text-decoration: none;
    line-height: 2.0;
    transition: color 240ms ease, transform 320ms cubic-bezier(0.22, 1, 0.36, 1);
}

.footer-links a:hover {
    color: #E6E6E6;
}

.footer-social {
    display: flex;
    align-items: center;
}

.social-icon {
    width: 38px;
    height: 38px;
    background-color: transparent;
    border-radius: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    transition: background-color 240ms ease, transform 320ms cubic-bezier(0.22, 1, 0.36, 1);
}

.social-icon:hover {
    background-color: transparent;
}

.social-icon img {
    width: 22px;
    height: 22px;
    display: block;
    object-fit: contain;
    filter: none;
}

.footer-legal {
    margin-top: 46px;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: 20px;
}

.legal-text {
    font-size: 10px;
    color: rgba(255, 255, 255, 0.45);
    line-height: 1.5;
}

.copyright {
    font-size: 10px;
    color: rgba(255, 255, 255, 0.45);
    line-height: 1.5;
}

.brand-name {
    color: rgba(255, 255, 255, 0.70);
}

/* Responsive Design */
@media (max-width: 900px) {
    .container {
        padding: 0 20px;
    }

    .feature-content {
        flex-direction: column;
    }

    .feature-image {
        width: 100%;
    }

    .feature-text {
        width: 100%;
    }

    .feature-paragraph {
        max-width: 100%;
    }

    .icon-row {
        flex-direction: column;
        gap: 28px;
    }

    .footer-content {
        flex-direction: column;
    }

    .footer-legal {
        flex-direction: column;
    }
}

@media (max-width: 600px) {
    .logo-badge {
        top: 32px;
        left: 37px;
        width: 56px;
        height: 56px;
        padding: 8px;
    }

    .logo-text {
        font-size: 12px;
    }

    .hero-content h1 {
        font-size: 36px;
    }

    .nav-links {
        gap: 18px;
        row-gap: 18px;
    }

    .statement-section {
        padding-top: 60px;
        padding-bottom: 40px;
    }

    .icon-section {
        padding-bottom: 60px;
    }

    .icon-row {
        gap: 40px;
    }

    .feature-block {
        padding-top: 50px;
        padding-bottom: 50px;
    }

    .feature-content {
        gap: 40px;
    }
}

/* ============================================
   PROJECTS PAGE STYLES
   ============================================ */

/* Projects Header */
.projects-header {
    background-color: #F3F3F3;
    padding-top: 26px;
    padding-bottom: 26px;
    width: 100%;
}

.projects-header .container {
    padding-left: 28px;
    padding-right: 28px;
    max-width: 100%;
}

.header-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: none;
    margin: 0 auto;
}

.header-logo-badge {
    width: 64px;
    height: 64px;
    background-color: transparent;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    flex-shrink: 0;
}

.header-logo-badge img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}

/* Ensure logo badge links don't show underline styling */
a.header-logo-badge,
a.logo-badge {
    text-decoration: none;
}

/* When the badge is used inside the generic nav strip */
.nav-strip .header-logo-badge {
    border-color: rgba(0, 0, 0, 0.2);
    /* Match home hero logo placement: 37px left, 32px top */
    margin-left: 9px; /* 28px container padding + 9px = 37px */
    margin-top: 6px;  /* 26px nav padding + 6px = 32px */
}

.header-logo-text {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    color: #333333;
    font-size: 14px;
    font-weight: 500;
    line-height: 1.05;
    text-align: left;
}

.header-logo-text span {
    display: block;
}

.header-nav {
    display: flex;
    gap: 38px;
    align-items: center;
}

.header-nav a {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: #555555;
    text-decoration: none;
    transition: color 240ms ease, transform 320ms cubic-bezier(0.22, 1, 0.36, 1);
}

.header-nav a:hover,
.header-nav a.active {
    color: #333333;
}

.header-nav a.active,
.header-nav a[aria-current="page"] {
    font-weight: 700 !important;
}

/* Project Hero Image */
.project-hero {
    width: 100%;
    height: 100vh;
    overflow: hidden;
}

.project-hero img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    animation: heroReveal 1800ms ease 200ms both;
}

@keyframes heroReveal {
    from {
        opacity: 0;
        transform: translateY(14px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@media (prefers-reduced-motion: reduce) {
    .project-hero img {
        animation: none;
    }
}

/* Project Meta Section */
.project-meta-section {
    background-color: #F3F3F3;
    padding-top: 46px;
    padding-bottom: 70px;
}

.project-meta-content {
    display: flex;
    gap: 56px;
    max-width: none;
    margin: 0 auto;
    padding: 0 40px;
    position: relative;
}

.project-meta-left {
    width: 22%;
    text-align: center;
    /* Keep meta block anchored at the left while right content is offset */
    position: absolute;
    left: 0;
    top: 0;
}

.meta-label {
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: #4B4B4B;
    font-weight: 200;
    margin: 0;
    white-space: nowrap;
}

.meta-details {
    margin-top: 30px;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.meta-details p {
    font-size: 17px;
    color: #111111;
    font-weight: 300; /* light */
    line-height: 1.35;
    margin: 0;
}

.project-meta-right {
    width: calc(100% - 437px);
    margin-left: 437px;
}

.project-title {
    font-size: 19px;
    font-weight: 100; /* thin */
    letter-spacing: 0.01em;
    color: #3D3D3D;
    margin: 0 0 26px 0;
    line-height: 1.25;
    text-transform: none;
    white-space: nowrap;
}

.project-description {
    font-size: 14px;
    font-weight: 300; /* light */
    line-height: 1.35;
    color: #111111;
    max-width: none;
    width: 100%;
    margin: 0 0 18px 0;
}

.project-button {
    width: 160px;
    height: 38px;
    border: 1px solid #111111;
    background: transparent;
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: #111111;
    cursor: pointer;
    transition: opacity 0.2s;
    font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    margin-top: 40px;
    margin-left: auto;
    margin-right: auto;
}

.project-button:hover {
    opacity: 0.75;
    transform: none;
}

/* Projects Content Section */
.projects-content-section {
    background-color: #FFFFFF;
    padding-top: 70px;
    padding-bottom: 120px;
}

.projects-content-layout {
    display: flex;
    gap: 56px;
    max-width: none;
    margin: 0 auto;
    padding: 0 40px;
}

.projects-left-column {
    width: 44%;
}

.projects-image-wrapper {
    margin-bottom: 24px;
}

.projects-image-wrapper img {
    width: 100%;
    height: auto;
    display: block;
    aspect-ratio: 4 / 3;
    object-fit: cover;
}

.projects-meta-below-image {
    margin-bottom: 20px;
}

.projects-meta-below-image p {
    font-size: 13px;
    color: #6A6A6A;
    line-height: 1.6;
    margin: 0;
}

.project-description-below {
    font-size: 14px;
    font-weight: 300;
    line-height: 1.35;
    color: #111111;
    max-width: none;
    margin: 0;
}

.projects-right-column {
    width: 56%;
    margin-top: 60px;
    padding-left: 30px;
}

.section-heading {
    font-size: 16px;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: #2F2F2F;
    font-weight: 300;
    margin: 10px 0 24px 0;
}

.past-projects-list {
    list-style: none;
    padding: 0;
    margin: 0;
    counter-reset: project-counter;
}

.past-projects-list li {
    padding: 4px 0;
    counter-increment: project-counter;
}

.past-projects-list li::before {
    content: counter(project-counter, decimal-leading-zero);
    color: #6A6A6A;
    font-size: 15px;
    font-weight: 200;
    display: inline-block;
    width: 28px;
}

.past-projects-list a {
    font-size: 15px;
    font-weight: 200;
    font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
    color: #6A6A6A;
    text-decoration: none;
    transition: color 240ms ease, transform 320ms cubic-bezier(0.22, 1, 0.36, 1);
    margin-left: 0;
    line-height: 1.2;
}

.past-projects-list a.is-active {
    font-weight: 700;
    color: #6A6A6A;
}

.past-project-detail {
    margin-top: 14px;
    font-size: 14px;
    font-weight: 300;
    color: #111111;
    line-height: 1.25;
    max-width: 520px;
    opacity: 0;
    transform: translateY(16px);
    transition: opacity 1600ms ease, transform 1600ms ease;
}

.past-project-detail.is-visible {
    opacity: 1;
    transform: translateY(0);
}

.past-project-note-meta p {
    margin: 0;
    font-size: 13px;
    line-height: 1.5;
    color: #6A6A6A;
    font-weight: 200;
}

.past-project-note-meta {
    margin-top: 12px;
    padding-bottom: 14px;
    margin-bottom: 18px;
}

.past-project-note-body {
    margin-top: 10px;
    font-weight: 300;
}

.past-projects-list a:hover {
    color: #6A6A6A;
}

/* Responsive for Projects Page */
@media (max-width: 900px) {
    .project-meta-content,
    .projects-content-layout {
        flex-direction: column;
    }

    .project-meta-left,
    .project-meta-right,
    .projects-left-column,
    .projects-right-column {
        width: 100%;
    }

    .projects-right-column {
        margin-top: 0;
        padding-left: 0;
    }

    .project-meta-content {
        position: static;
    }

    .project-meta-left {
        position: static;
    }

    .project-meta-right {
        margin-left: 0;
        width: 100%;
    }

    .project-description {
        max-width: 100%;
        width: 100%;
    }

    .header-content {
        flex-direction: column;
        gap: 20px;
        align-items: flex-start;
    }

    .header-nav {
        width: 100%;
        justify-content: flex-start;
        flex-wrap: wrap;
    }
}

@media (max-width: 600px) {
    .projects-header .container {
        padding-left: 20px;
        padding-right: 20px;
    }

    .project-meta-content,
    .projects-content-layout {
        padding: 0 20px;
    }

    .meta-label {
        white-space: normal;
    }

    .meta-details p {
        font-size: 15px;
    }

    .header-nav {
        gap: 18px;
    }
}

@media (max-width: 800px) {
    .project-title {
        white-space: normal;
    }
}

/* Journal */
.journal {
    max-width: 900px;
    margin: 0 auto;
    padding: 80px 24px;
}

.journal-title {
    font-size: 28px;
    font-weight: 400;
    letter-spacing: 0.02em;
    margin-bottom: 32px;
}

.journal-list {
    list-style: none;
    padding: 0;
    margin: 0;
    border-top: 1px solid #D8D8D8;
}

.journal-item {
    border-bottom: 1px solid #D8D8D8;
}

.journal-item-link {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 24px;
    padding: 28px 0;
    text-decoration: none;
    color: #2B2B2B;
    transition: opacity 0.2s ease;
}

.journal-item-link:hover {
    opacity: 0.55;
}

.journal-item-title {
    font-size: clamp(15px, 1.8vw, 18px);
    font-weight: 300;
    letter-spacing: 0.01em;
}

.journal-item-date {
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #888;
    white-space: nowrap;
}

/* Journal entry detail */
.journal-entry-page {
    background-color: #F3F3F3;
    min-height: 100vh;
    padding: 80px 24px 120px;
}

.journal-entry-container {
    max-width: 680px;
    margin: 0 auto;
}

.journal-back {
    display: inline-block;
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #6B6B6B;
    text-decoration: none;
    margin-bottom: 60px;
    transition: opacity 0.2s ease;
}

.journal-back:hover {
    opacity: 0.6;
}

.journal-entry-header {
    margin-bottom: 48px;
}

.journal-entry-date {
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #888;
    margin: 0 0 18px;
}

.journal-entry-title {
    font-size: clamp(24px, 3.2vw, 36px);
    font-weight: 300;
    line-height: 1.3;
    color: #2B2B2B;
    margin: 0;
}

.journal-entry-body p {
    font-size: 15px;
    line-height: 1.85;
    color: #444;
    margin: 0 0 24px;
}

/* About */
.about-page .nav-strip {
    background-color: #FFFFFF;
}

/* Contact */
.contact-page .nav-strip {
    background-color: #FFFFFF;
}

.about-section {
    width: 100%;
    background-color: #F1F1F1;
    padding-top: 140px;
    padding-bottom: 140px;
}

.about-container {
    max-width: 980px;
}

.about-kicker {
    margin: 0 0 40px 0;
    text-align: center;
    font-size: 11px;
    letter-spacing: 0.20em;
    color: #6B6B6B;
    text-transform: uppercase;
}

.about-title {
    margin: 0 auto 24px auto;
    text-align: center;
    max-width: 620px;
    font-size: clamp(22px, 2.6vw, 28px);
    line-height: 1.4;
    font-weight: 300;
    color: #2B2B2B;
}

.about-intro {
    margin: 0 auto 60px auto;
    text-align: center;
    max-width: 520px;
    font-size: 13px;
    line-height: 1.75;
    color: #777;
}


.about-icons-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 64px 80px;
    margin-top: 64px;
    max-width: 700px;
    margin-left: auto;
    margin-right: auto;
}

.about-icon-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

@media (max-width: 520px) {
    .about-icons-grid {
        grid-template-columns: 1fr;
        gap: 48px;
    }
}

.about-icon-img {
    width: 56px;
    height: 56px;
    object-fit: contain;
    margin-bottom: 18px;
}

.about-icon-label {
    font-size: 13px;
    font-weight: 600;
    color: #2B2B2B;
    letter-spacing: 0.01em;
    margin: 0 0 10px;
    line-height: 1.3;
}

.about-icon-desc {
    font-size: 13px;
    font-weight: 300;
    color: #777;
    line-height: 1.7;
    margin: 0;
}

.about-cta {
    display: block;
    width: fit-content;
    margin: 70px auto 0 auto;
    padding: 10px 34px;
    border: 1px solid #2B2B2B;
    color: #2B2B2B;
    background: transparent;
    text-decoration: none;
    text-transform: uppercase;
    font-size: 10px;
    letter-spacing: 0.20em;
    transition: opacity 0.2s ease;
}

.about-cta:hover {
    opacity: 0.75;
}

/* Contact */
.contact-section {
    background-color: #F3F3F3;
    padding-top: 110px;
    padding-bottom: 110px;
}

.contact-kicker {
    margin: 0 0 22px 0;
    text-align: center;
    font-size: 11px;
    letter-spacing: 0.20em;
    color: #6B6B6B;
    text-transform: uppercase;
}

.contact-title {
    text-align: center;
    font-size: clamp(26px, 3vw, 32px);
    line-height: 1.25;
    font-weight: 300;
    color: #2B2B2B;
    margin: 0;
}

.contact-form {
    margin: 40px auto 0 auto;
    max-width: 560px;
    display: grid;
    gap: 14px;
}

.contact-honeypot {
    display: none;
}

.contact-field {
    display: grid;
    gap: 8px;
}

.contact-label {
    font-size: 10px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #6B6B6B;
}

.contact-field input,
.contact-field textarea {
    width: 100%;
    border: 1px solid rgba(0, 0, 0, 0.18);
    background-color: #FFFFFF;
    padding: 12px 14px;
    font-size: 14px;
    font-weight: 300;
    line-height: 1.4;
    color: #111111;
    font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
    outline: none;
}

.contact-field textarea {
    resize: vertical;
}

.contact-field input:focus,
.contact-field textarea:focus {
    border-color: rgba(0, 0, 0, 0.34);
}

.contact-submit {
    margin: 18px auto 0 auto;
    padding: 10px 34px;
    border: 1px solid #2B2B2B;
    color: #2B2B2B;
    background: transparent;
    text-decoration: none;
    text-transform: uppercase;
    font-size: 10px;
    letter-spacing: 0.20em;
    transition: opacity 240ms ease, transform 320ms cubic-bezier(0.22, 1, 0.36, 1);
    cursor: pointer;
    width: fit-content;
}

.contact-submit:hover {
    opacity: 0.75;
    transform: translateY(-2px);
}

.contact-submit:active {
    transform: translateY(0);
}

@media (max-width: 700px) {
    .about-section {
        padding-top: 90px;
        padding-bottom: 90px;
    }

    .about-title {
        margin-bottom: 48px;
    }

    .about-grid {
        grid-template-columns: 1fr;
        row-gap: 18px;
        justify-content: start;
        max-width: 520px;
        margin: 0 auto;
    }

    .about-label {
        text-align: left;
    }

    .contact-section {
        padding-top: 90px;
        padding-bottom: 90px;
    }
}

