/* ============================================
   STYLE.CSS — homepage + About + Case-studies
   index layouts. Tokens and primitives live in
   tokens.css + base.css. Light editorial system.
   ============================================ */

/* ============================================
   HOMEPAGE — HERO
   ============================================ */

.hero {
    position: relative;
    background: var(--aura-corner-wash);
    padding: clamp(3.5rem, 6vw, 5rem) 0 clamp(3.5rem, 6vw, 5.5rem);
    overflow: hidden;
}

.hero-layout {
    display: grid;
    gap: 48px;
    align-items: center;
}
@media (min-width: 960px) {
    .hero-layout { grid-template-columns: 1.05fr 0.95fr; gap: 56px; }
}

.hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--surface-soft-tint);
    color: var(--main-accent);
    font-weight: 600;
    font-size: var(--fs-micro);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 6px 12px;
    border-radius: var(--radius-pill);
    border: 1px solid rgba(20, 30, 200, 0.15);
    margin-bottom: 24px;
}

.hero__title {
    font-size: var(--fs-h1);
    letter-spacing: -0.03em;
    line-height: 1.04;
    text-wrap: balance;
    margin-bottom: 20px;
}

.hero__description {
    font-size: var(--fs-lead);
    color: var(--fg-2);
    line-height: 1.5;
    max-width: 56ch;
    margin-bottom: 8px;
}

/* Action card (right column of the hero) */
.hero-card {
    background: var(--white);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-2xl);
    padding: 28px 24px;
    box-shadow: var(--shadow-lg);
}
@media (min-width: 720px) { .hero-card { padding: 32px 28px; } }
.hero-card__title {
    font-size: 1.3rem;
    letter-spacing: -0.02em;
    margin-bottom: 6px;
}
.hero-card__hint {
    font-size: var(--fs-small);
    color: var(--fg-3);
    margin-bottom: 18px;
}
.hero-card .aeo-capture { display: grid; gap: 12px; }
.hero-card .aeo-capture input {
    width: 100%;
    min-height: 52px;
    padding: 13px 16px;
    border: 1.5px solid var(--border-subtle);
    border-radius: var(--radius-md);
    font: inherit;
    font-size: 16px;
    background: var(--surface-sunken);
    color: var(--fg-1);
    transition: border-color var(--transition-fast), background var(--transition-fast);
}
.hero-card .aeo-capture input:focus {
    outline: 2px solid var(--main-accent);
    outline-offset: 0;
    border-color: var(--main-accent);
    background: var(--white);
}
.hero-card .aeo-capture .btn { width: 100%; min-height: 52px; }
.hero-card .field label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    margin-bottom: 6px;
    color: var(--fg-2);
}
.hero-card .form-error {
    display: none;
    background: #FEF2F2;
    border: 1px solid #FCA5A5;
    color: #B91C1C;
    border-radius: var(--radius-md);
    padding: 10px 12px;
    font-size: 13.5px;
    margin-bottom: 12px;
}

/* thanks + upsell state inside the hero card */
.hero-thanks { display: none; }
.hero-thanks .tick {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background: #DCFCE7;
    color: #15803D;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 26px;
    margin-bottom: 14px;
}
.hero-thanks h2 { font-size: 1.3rem; letter-spacing: -0.02em; margin-bottom: 6px; }
.hero-thanks > p { font-size: 14.5px; color: var(--fg-2); }
.hero-thanks .upsell {
    margin-top: 20px;
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-lg);
    padding: 18px 16px;
    background: var(--surface-soft-tint);
}
.hero-thanks .upsell h3 { font-size: 1.02rem; letter-spacing: -0.01em; margin-bottom: 4px; }
.hero-thanks .upsell p { font-size: 13.5px; color: var(--fg-2); margin-bottom: 12px; }
.hero-thanks .upsell input {
    width: 100%;
    min-height: 46px;
    padding: 11px 13px;
    border: 1.5px solid var(--border-subtle);
    border-radius: var(--radius-md);
    font: inherit;
    font-size: 15px;
    background: var(--white);
    margin-bottom: 10px;
}
.hero-thanks .upsell input:focus { outline: 2px solid var(--main-accent); border-color: var(--main-accent); }
.hero-thanks .upsell .btn { width: 100%; min-height: 48px; font-size: 15px; }

/* nav-CTA scroll target highlight */
@keyframes cardFlash {
    0% { box-shadow: var(--shadow-lg); }
    30% { box-shadow: 0 0 0 5px rgba(20, 30, 200, 0.22), var(--shadow-brand-glow); }
    100% { box-shadow: var(--shadow-lg); }
}
.hero-card.flash { animation: cardFlash 1.1s cubic-bezier(0.22, 1, 0.36, 1) 2; }

.aeo-note {
    font-size: var(--fs-caption);
    color: var(--fg-3);
    margin-top: 14px;
    text-align: center;
}
.hero-card__logos {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
    margin-top: 20px;
    padding-top: 18px;
    border-top: 1px solid var(--border-subtle);
}
.hero-card__logos img {
    width: 30px;
    height: 30px;
    border-radius: 8px;
    border: 1px solid var(--border-subtle);
    object-fit: contain;
    background: var(--white);
    opacity: 0.85;
}
.hero-card__logos span {
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--fg-3);
    letter-spacing: 0.04em;
}

/* Proof quotes under the hero copy */
.hero-proof {
    display: grid;
    gap: 12px;
    margin-top: 28px;
}
@media (min-width: 640px) { .hero-proof { grid-template-columns: 1fr 1fr; } }
.hero-proof li {
    display: grid;
    grid-template-columns: 36px 1fr;
    grid-template-rows: auto auto;
    column-gap: 12px;
    align-items: center;
    background: var(--white);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-lg);
    padding: 12px 14px;
    box-shadow: var(--shadow-sm);
}
.hero-proof__avatar {
    grid-row: 1 / 3;
    width: 36px;
    height: 36px;
    border-radius: 9px;
    border: 1px solid var(--border-subtle);
    background: var(--white);
    overflow: hidden;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.hero-proof__avatar img { width: 100%; height: 100%; object-fit: contain; padding: 2px; }
.hero-proof__avatar--light { background: var(--white); }
.hero-proof__quote {
    font-size: 13.5px;
    font-weight: 500;
    color: var(--fg-1);
    line-height: 1.35;
}
.hero-proof__who {
    font-family: var(--font-mono);
    font-size: 10.5px;
    letter-spacing: 0.04em;
    color: var(--fg-3);
    margin-top: 2px;
}

/* Legacy hero logo (no longer used on the homepage) */
.hero__visual { display: none; }

/* ============================================
   LADDER (homepage services overview)
   ============================================ */

.ladder { display: grid; gap: 16px; margin-top: 36px; }
@media (min-width: 880px) { .ladder { grid-template-columns: repeat(4, 1fr); } }
.ladder-step {
    position: relative;
    background: var(--white);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-xl);
    padding: 24px 22px;
    box-shadow: var(--shadow-sm);
    transition: box-shadow var(--transition-base), transform var(--transition-base);
}
.ladder-step:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.ladder-step .ln {
    display: block;
    font-family: var(--font-mono);
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.08em;
    color: var(--main-accent);
    margin-bottom: 14px;
}
.ladder-step h3 { font-size: 1.1rem; margin-bottom: 8px; letter-spacing: -0.01em; }
.ladder-step p { font-size: var(--fs-small); color: var(--fg-2); }
.ladder-step .tag {
    position: absolute;
    top: 20px;
    right: 20px;
    font-family: var(--font-mono);
    font-size: 10.5px;
    font-weight: 500;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--complementary-1);
}

/* ============================================
   VALUE PROP
   ============================================ */

.value-prop { background: var(--surface-sunken); }
.value-prop__grid {
    display: grid;
    gap: 40px;
    align-items: center;
}
@media (min-width: 960px) { .value-prop__grid { grid-template-columns: 1.05fr 0.95fr; gap: 64px; } }
.value-prop__title {
    font-size: var(--fs-title);
    letter-spacing: -0.03em;
    line-height: 1.08;
    margin-bottom: 16px;
    text-wrap: balance;
}
.value-prop__lead { font-size: var(--fs-lead); color: var(--fg-2); line-height: 1.55; }
.value-prop__card { padding: 28px; }
.value-prop__list { display: grid; gap: 18px; }
.value-prop__list li {
    display: grid;
    grid-template-columns: 24px 1fr;
    gap: 14px;
    align-items: start;
    font-size: 15px;
    color: var(--fg-1);
    line-height: 1.45;
}
.value-prop__list svg { width: 22px; height: 22px; stroke: var(--main-accent); margin-top: 1px; }
.value-prop__note {
    display: flex;
    gap: 12px;
    align-items: flex-start;
    margin-top: 22px;
    padding: 14px 16px;
    background: var(--surface-soft-tint);
    border-radius: var(--radius-lg);
    font-size: var(--fs-small);
    color: var(--fg-2);
}
.value-prop__note-icon { color: var(--main-accent); flex-shrink: 0; }

/* ============================================
   SOCIAL PROOF / LOGO STRIP
   ============================================ */

.social-proof {
    padding: 36px 0 48px;
    background: var(--white);
    border-bottom: 1px solid var(--border-subtle);
}
.social-proof__label {
    text-align: center;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--fg-3);
    margin-bottom: 22px;
}
.social-proof__logos {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 20px 40px;
}
.social-proof__logos li {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    opacity: 0.75;
    transition: opacity var(--transition-base);
}
.social-proof__logos li:hover { opacity: 1; }
.social-proof__logos img {
    width: 48px;
    height: 48px;
    border-radius: 10px;
    background: var(--white);
    border: 1px solid var(--border-subtle);
    box-shadow: var(--shadow-sm);
    object-fit: contain;
    padding: 5px;
}
.social-proof__logos span {
    font-size: 11px;
    color: var(--fg-3);
    font-weight: 500;
}

/* ============================================
   SERVICES / FEATURES GRID
   ============================================ */

.services__heading { max-width: 640px; margin-bottom: 44px; }
.services-grid { display: grid; gap: 20px; }
@media (min-width: 720px) { .services-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .services-grid { grid-template-columns: repeat(3, 1fr); } }
.service-card {
    display: flex;
    flex-direction: column;
    gap: 0;
    padding: 26px 24px;
}
.service-card__icon {
    width: 46px;
    height: 46px;
    border-radius: var(--radius-md);
    background: var(--surface-soft-tint);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 18px;
}
.service-card__icon svg { width: 22px; height: 22px; stroke: var(--main-accent); }
.service-card__title { font-size: 1.08rem; margin-bottom: 8px; letter-spacing: -0.01em; }
.service-card__description { font-size: var(--fs-small); color: var(--fg-2); line-height: 1.5; }
.service-card__meta {
    margin-top: auto;
    padding-top: 16px;
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.04em;
    color: var(--fg-3);
}

/* ============================================
   SHOWCASE (case-study feature frames)
   ============================================ */

.showcase__frame { background: var(--surface-sunken); }
.showcase__grid {
    display: grid;
    gap: 32px;
    align-items: center;
}
@media (min-width: 960px) {
    .showcase__grid { grid-template-columns: 1fr 1.1fr; gap: 48px; }
    .showcase__frame--reverse .showcase__grid { grid-template-columns: 1.1fr 1fr; }
}
.showcase__label-badge {
    display: inline-flex;
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--complementary-1);
    margin-bottom: 14px;
}
.showcase__title {
    font-size: var(--fs-title-sm);
    letter-spacing: -0.02em;
    line-height: 1.1;
    margin-bottom: 14px;
    text-wrap: balance;
}
.showcase__description { font-size: 15.5px; color: var(--fg-2); line-height: 1.55; margin-bottom: 20px; }
.showcase__link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-weight: 600;
    font-size: var(--fs-small);
    color: var(--main-accent);
}
.showcase__link:hover { color: var(--main-accent-dark); }
.showcase__window {
    background: var(--white);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-md);
}
.showcase__window-media img { width: 100%; display: block; }
.showcase__stack { display: grid; gap: 24px; }
.showcase__side { display: flex; flex-wrap: wrap; gap: 12px; }
.showcase__proof-card {
    display: inline-flex;
    flex-direction: column;
    gap: 2px;
    background: var(--white);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-lg);
    padding: 12px 18px;
    box-shadow: var(--shadow-sm);
}
.showcase__proof-label {
    font-family: var(--font-mono);
    font-size: 10.5px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--fg-3);
}
.showcase__proof-value {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 1.05rem;
    color: var(--fg-1);
}
.showcase__proof-card--accent .showcase__proof-value { color: var(--main-accent); }
.showcase__proof-card--magenta .showcase__proof-value { color: var(--complementary-1); }

.showcase__badge {
    display: inline-flex;
    flex-direction: column;
    gap: 2px;
    margin-top: 24px;
    background: var(--white);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-lg);
    padding: 12px 18px;
    box-shadow: var(--shadow-sm);
}
.showcase__badge-label {
    font-family: var(--font-mono);
    font-size: 10.5px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--fg-3);
}
.showcase__badge-value {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 1.1rem;
    color: var(--fg-1);
}

/* ============================================
   FEATURED PULL-QUOTE
   ============================================ */

.featured-quote {
    padding: var(--section-pad-y-sm) 0;
    text-align: center;
}
.featured-quote__mark {
    width: 40px;
    height: 30px;
    color: var(--complementary-1);
    opacity: 0.35;
    margin: 0 auto 22px;
}
.featured-quote__text {
    font-family: var(--font-serif-italic);
    font-style: italic;
    font-weight: 400;
    font-size: clamp(1.4rem, 3vw, 2rem);
    line-height: 1.25;
    color: var(--fg-1);
    max-width: 26ch;
    margin: 0 auto 28px;
    text-wrap: balance;
}
.featured-quote__author {
    display: inline-flex;
    align-items: center;
    gap: 14px;
    text-align: left;
}
.featured-quote__avatar { width: 44px; height: 44px; border-radius: 10px; }
.featured-quote__name { font-weight: 600; font-size: var(--fs-small); }
.featured-quote__role { font-size: var(--fs-caption); color: var(--fg-3); }

/* ============================================
   TESTIMONIALS
   ============================================ */

.testimonials__heading { text-align: center; max-width: 620px; margin: 0 auto 48px; }
.testimonials-grid { display: grid; gap: 20px; }
@media (min-width: 720px) { .testimonials-grid { grid-template-columns: repeat(2, 1fr); } }
.testimonial-card {
    background: var(--white);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-xl);
    padding: 26px;
    box-shadow: var(--shadow-sm);
    display: flex;
    flex-direction: column;
    gap: 18px;
    margin: 0;
}
.testimonial-card__metric {
    font-family: var(--font-mono);
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.05em;
    color: var(--main-accent);
    text-transform: uppercase;
}
.testimonial-card blockquote {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: 16.5px;
    line-height: 1.45;
    letter-spacing: -0.01em;
    color: var(--fg-1);
    margin: 0;
}
.testimonial-card figcaption {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: auto;
}
.testimonial-card figcaption .hero-proof__avatar { grid-row: auto; width: 40px; height: 40px; }
.testimonial-card__who { display: block; font-weight: 600; font-size: var(--fs-small); color: var(--fg-1); }
.testimonial-card__role { display: block; font-size: var(--fs-caption); color: var(--fg-3); }

/* ============================================
   PROJECTS (case-studies grid)
   ============================================ */

.projects__frame { background: var(--surface-sunken); }
.projects__heading { max-width: 640px; margin-bottom: 36px; }
.projects__lead { font-size: 15.5px; color: var(--fg-2); margin-top: 12px; }
.projects-grid { display: grid; gap: 20px; }
@media (min-width: 720px) { .projects-grid { grid-template-columns: repeat(2, 1fr); } }
.project-card {
    background: var(--white);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-xl);
    padding: 22px;
    box-shadow: var(--shadow-sm);
    display: flex;
    flex-direction: column;
    gap: 16px;
    transition: box-shadow var(--transition-base), transform var(--transition-base);
}
.project-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.project-card__header { display: flex; align-items: center; gap: 12px; }
.project-card__header .hero-proof__avatar { grid-row: auto; width: 38px; height: 38px; }
.project-card__client { font-weight: 600; font-size: var(--fs-small); }
.project-card__image {
    border-radius: var(--radius-lg);
    overflow: hidden;
    border: 1px solid var(--border-subtle);
}
.project-card__image img { width: 100%; display: block; }
.project-card__quote { font-size: var(--fs-small); color: var(--fg-2); line-height: 1.5; }
.project-card__link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-weight: 600;
    font-size: var(--fs-small);
    color: var(--main-accent);
    margin-top: auto;
}
.project-card__link:hover { color: var(--main-accent-dark); }
.projects__cta { margin-top: 32px; text-align: center; }

/* ============================================
   PROCESS
   ============================================ */

.process__heading { text-align: center; max-width: 560px; margin: 0 auto 48px; }
.process-grid { display: grid; gap: 18px; }
@media (min-width: 880px) { .process-grid { grid-template-columns: repeat(4, 1fr); } }
.process-step {
    background: var(--white);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-xl);
    padding: 24px 22px;
    box-shadow: var(--shadow-sm);
}
.process-step__number {
    font-family: var(--font-mono);
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.08em;
    color: var(--main-accent);
    margin-bottom: 14px;
}
.process-step__title { font-size: 1.05rem; margin-bottom: 8px; }
.process-step__description { font-size: var(--fs-small); color: var(--fg-2); }

/* ============================================
   FINAL CTA (dark aura panel)
   ============================================ */

.cta { padding: 0 0 var(--section-pad-y); }
.cta .container {
    background: var(--aura-gradient);
    border-radius: var(--radius-2xl);
    padding: clamp(48px, 7vw, 88px) clamp(24px, 5vw, 72px);
    text-align: center;
    color: var(--white);
    max-width: calc(var(--container) - 48px);
}
.cta__title {
    font-size: var(--fs-title);
    letter-spacing: -0.03em;
    line-height: 1.08;
    color: var(--white);
    max-width: 22ch;
    margin: 0 auto 18px;
    text-wrap: balance;
}
.cta__description {
    font-size: var(--fs-lead);
    color: rgba(255, 255, 255, 0.82);
    max-width: 58ch;
    margin: 0 auto 30px;
    line-height: 1.55;
}
.cta__email {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: var(--white);
    color: var(--gray-950);
    font-family: var(--font-display);
    font-weight: 600;
    font-size: clamp(1rem, 2vw, 1.2rem);
    padding: 16px 28px;
    border-radius: 14px;
    box-shadow: 0 16px 48px rgba(0, 0, 0, 0.3);
    transition: transform var(--transition-base);
}
.cta__email:hover { transform: translateY(-2px); }
.cta__email svg { stroke: var(--gray-950); }

/* ============================================
   ABOUT — MISSION / VALUES
   ============================================ */

.mission__grid { display: grid; gap: 40px; align-items: center; }
@media (min-width: 960px) { .mission__grid { grid-template-columns: 1fr 1fr; gap: 64px; } }
.mission__heading { margin-bottom: 8px; }
.mission__lead { font-size: var(--fs-lead); color: var(--fg-2); line-height: 1.55; margin-bottom: 28px; }
.mission__image {
    border-radius: var(--radius-xl);
    overflow: hidden;
    border: 1px solid var(--border-subtle);
    box-shadow: var(--shadow-lg);
}
.mission__image img { width: 100%; display: block; }
.mission__points { display: grid; gap: 16px; }
.mission-point {
    display: grid;
    grid-template-columns: 44px 1fr;
    gap: 16px;
    align-items: start;
    background: var(--white);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-lg);
    padding: 18px;
    box-shadow: var(--shadow-sm);
}
.mission-point__icon {
    width: 44px;
    height: 44px;
    border-radius: var(--radius-md);
    background: var(--surface-soft-tint);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.mission-point__icon svg { width: 20px; height: 20px; stroke: var(--main-accent); }
.mission-point__title { font-size: 1rem; margin-bottom: 4px; }
.mission-point__description { font-size: var(--fs-small); color: var(--fg-2); }

.values__heading { text-align: center; max-width: 560px; margin: 0 auto 44px; }
.values-grid { display: grid; gap: 20px; }
@media (min-width: 880px) { .values-grid { grid-template-columns: repeat(3, 1fr); } }
.value-card {
    background: var(--white);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-xl);
    padding: 26px 24px;
    box-shadow: var(--shadow-sm);
}
.value-card__icon {
    width: 46px;
    height: 46px;
    border-radius: var(--radius-md);
    background: var(--surface-soft-tint);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 16px;
}
.value-card__icon svg { width: 22px; height: 22px; stroke: var(--main-accent); }
.value-card__title { font-size: 1.08rem; margin-bottom: 8px; }
.value-card__description { font-size: var(--fs-small); color: var(--fg-2); }

/* ============================================
   PORTFOLIO (case-studies index)
   ============================================ */

.portfolio__frame { background: var(--surface-sunken); }
.portfolio__heading { max-width: 640px; margin-bottom: 36px; }
.portfolio-grid { display: grid; gap: 20px; }
@media (min-width: 880px) { .portfolio-grid { grid-template-columns: repeat(2, 1fr); } }
.portfolio-card {
    background: var(--white);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    display: flex;
    flex-direction: column;
    transition: box-shadow var(--transition-base), transform var(--transition-base);
}
.portfolio-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.portfolio-card__image { border-bottom: 1px solid var(--border-subtle); }
.portfolio-card__image img { width: 100%; display: block; }
.portfolio-card__body { padding: 22px; display: flex; flex-direction: column; gap: 12px; flex: 1; }
.portfolio-card__brand { display: flex; align-items: center; gap: 10px; }
.portfolio-card__brand-name { font-weight: 600; font-size: var(--fs-small); }
.portfolio-card__name, .portfolio-card__title { font-size: 1.15rem; letter-spacing: -0.01em; }
.portfolio-card__desc, .portfolio-card__quote { font-size: var(--fs-small); color: var(--fg-2); line-height: 1.5; }
.portfolio-card__tags { display: flex; flex-wrap: wrap; gap: 8px; }
.portfolio-card__tag {
    font-family: var(--font-mono);
    font-size: 10.5px;
    letter-spacing: 0.04em;
    color: var(--fg-3);
    background: var(--surface-sunken);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-pill);
    padding: 4px 10px;
}
.portfolio-card__link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-weight: 600;
    font-size: var(--fs-small);
    color: var(--main-accent);
    margin-top: auto;
}

/* ============================================
   PAGE-LEVEL HERO VARIANTS (about / case-studies)
   Light heroes — the old dark gradient levels
   are retired; both levels share the corner wash.
   ============================================ */

.page-level-1 .hero,
.page-level-2 .hero {
    background: var(--aura-corner-wash);
    color: var(--fg-1);
}
