/* -------------------------------------------------------------------
   Work Page - Bento Grid Portfolio
   Matching Kindred design system
------------------------------------------------------------------- */

/* Header Section */
.work-header-section {
    padding: calc(100px + var(--space-3xl)) var(--side-padding) var(--space-2xl);
    background-color: var(--color-bg);
}

.work-page-title {
    font-family: var(--font-heading);
    font-size: clamp(2.5rem, 5vw, 3.5rem);
    font-weight: 400;
    line-height: 1.1;
    color: var(--color-text-primary);
    margin: 0 0 var(--space-md);
    opacity: 0;
    transform: translateY(20px);
}

.work-page-subtitle {
    font-family: var(--font-body);
    font-size: var(--text-lg);
    font-weight: 400;
    line-height: 1.5;
    color: var(--color-text-primary);
    margin: 0;
    max-width: 700px;
    opacity: 0;
    transform: translateY(20px);
}

/* Animation classes */
.work-page-title.animate-in,
.work-page-subtitle.animate-in {
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.6s var(--ease-smooth), transform 0.6s var(--ease-smooth);
}

.work-page-subtitle.animate-in {
    transition-delay: 0.1s;
}

/* -------------------------------------------------------------------
   Bento Grid Section
------------------------------------------------------------------- */
.work-bento-section {
    padding: 0 var(--side-padding) var(--space-3xl);
    background-color: var(--color-bg);
}

.bento-grid {
    display: flex;
    gap: 24px;
    align-items: stretch;
    max-width: 1400px;
    margin: 0 auto;
}

/* -------------------------------------------------------------------
   Bento Card Base
------------------------------------------------------------------- */
.bento-card {
    display: flex;
    flex-direction: column;
    text-decoration: none;
    background: #F5EDE3;
    border-radius: 24px;
    padding: 16px;
    transition: transform 0.4s var(--ease-smooth);
    opacity: 0;
    transform: translateY(30px);
}

.bento-card.animate-in {
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.6s var(--ease-smooth), transform 0.6s var(--ease-smooth);
}

.bento-card:hover {
    transform: translateY(-4px);
}

/* -------------------------------------------------------------------
   Featured Card (Large - Left)
------------------------------------------------------------------- */
.bento-featured {
    flex: 1;
    min-width: 0;
}

.bento-featured .bento-image-box {
    display: block;
    overflow: hidden;
    margin-bottom: 16px;
    border-radius: 40px;
    background: #fff;
}

.bento-featured .bento-image-box img {
    width: 100%;
    height: auto;
    max-height: 100%;
    object-fit: contain;
    object-position: center;
    display: block;
    transition: transform 0.5s var(--ease-smooth);
}

.bento-featured:hover .bento-image-box img {
    transform: scale(1.02);
}

.bento-card-info {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.bento-tag {
    display: inline-block;
    width: fit-content;
    font-family: var(--font-body);
    font-size: 0.6875rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: rgba(0, 0, 0, 0.8);
    padding: 0.375rem 0.75rem;
    border-radius: 6px;
}

/* Soft pastel color variants */
.bento-tag-lime {
    background: #E8F5D0;
}

.bento-tag-yellow {
    background: #FFF4DC;
}

.bento-tag-blue {
    background: #E0F4FF;
}

.bento-tag-pink {
    background: #FFE4F1;
}

.bento-tag-purple {
    background: #EDE4FF;
}

.bento-card-title {
    font-family: var(--font-heading);
    font-size: clamp(24px, 3vw, 32px);
    font-weight: 400;
    line-height: 1.3;
    color: #1a1a1a;
    margin: 0;
}

/* -------------------------------------------------------------------
   Small Stacked Cards (Right Column)
------------------------------------------------------------------- */
.bento-stack {
    display: flex;
    flex-direction: column;
    gap: 16px;
    width: 320px;
    flex-shrink: 0;
}

.bento-small {
    flex: 1;
    padding: 12px;
    border-radius: 16px;
}

.bento-image-box-small {
    background: #fff;
    border-radius: 8px;
    overflow: hidden;
    margin-bottom: 10px;
    flex: 1;
}

.bento-image-box-small img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top;
    display: block;
    transition: transform 0.5s var(--ease-smooth);
}

.bento-small:hover .bento-image-box-small img {
    transform: scale(1.02);
}

.bento-card-info-small {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.bento-tag-small {
    display: inline-block;
    width: fit-content;
    font-family: var(--font-body);
    font-size: 0.5625rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: rgba(0, 0, 0, 0.8);
    padding: 0.3125rem 0.5rem;
    border-radius: 4px;
}

.bento-card-title-small {
    font-family: var(--font-heading);
    font-size: 15px;
    font-weight: 400;
    line-height: 1.3;
    color: #1a1a1a;
    margin: 0;
}

/* -------------------------------------------------------------------
   Stats Section
------------------------------------------------------------------- */
.work-stats-section {
    padding: var(--space-3xl) var(--side-padding);
    background-color: var(--color-bg);
}

.work-stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-xl);
    max-width: 1200px;
    margin: 0 auto;
    text-align: center;
}

.work-stat {
    padding: var(--space-lg);
}

.stat-number {
    font-family: var(--font-heading);
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 400;
    line-height: 1.1;
    color: var(--color-text-primary);
    display: block;
    margin-bottom: var(--space-xs);
}

.stat-label {
    font-family: var(--font-body);
    font-size: var(--text-sm);
    font-weight: 400;
    color: var(--color-text-secondary);
    display: block;
}

/* -------------------------------------------------------------------
   What We Deliver Section
------------------------------------------------------------------- */
.work-deliver-section {
    padding: var(--space-3xl) var(--side-padding);
    background-color: var(--color-bg);
}

.deliver-header {
    max-width: 700px;
    margin: 0 auto var(--space-2xl);
    text-align: center;
}

.section-headline {
    font-family: var(--font-heading);
    font-size: clamp(2rem, 4vw, 2.75rem);
    font-weight: 400;
    line-height: 1.2;
    color: var(--color-text-primary);
    margin: 0 0 var(--space-md);
}

.section-subheadline {
    font-family: var(--font-body);
    font-size: var(--text-lg);
    font-weight: 400;
    line-height: 1.5;
    color: var(--color-text-secondary);
    margin: 0;
}

.deliver-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-lg);
    max-width: 1200px;
    margin: 0 auto;
}

.deliver-card {
    padding: var(--space-xl);
    background: var(--color-bg-beige, #F5F0E8);
    border-radius: var(--radius-xl);
    border: 1px solid rgba(0, 0, 0, 0.04);
    transition: transform 0.3s var(--ease-smooth);
}

.deliver-card:hover {
    transform: translateY(-4px);
}

.deliver-icon {
    width: 48px;
    height: 48px;
    margin-bottom: var(--space-md);
    color: var(--color-text-primary);
}

.deliver-icon svg {
    width: 100%;
    height: 100%;
}

.deliver-title {
    font-family: var(--font-body);
    font-size: var(--text-lg);
    font-weight: 500;
    color: var(--color-text-primary);
    margin: 0 0 var(--space-sm);
}

.deliver-desc {
    font-family: var(--font-body);
    font-size: var(--text-sm);
    font-weight: 400;
    line-height: 1.6;
    color: var(--color-text-secondary);
    margin: 0;
}

/* -------------------------------------------------------------------
   How We Work / Process Section
------------------------------------------------------------------- */
.work-process-section {
    padding: var(--space-3xl) var(--side-padding);
    background-color: var(--color-bg);
}

.process-header {
    max-width: 700px;
    margin: 0 auto var(--space-2xl);
    text-align: center;
}

.process-timeline {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-lg);
    max-width: 1200px;
    margin: 0 auto;
}

.process-step {
    position: relative;
    padding: var(--space-lg);
}

.step-number {
    font-family: var(--font-heading);
    font-size: clamp(3rem, 6vw, 4.5rem);
    font-weight: 400;
    line-height: 1;
    color: var(--color-text-primary);
    opacity: 0.15;
    margin-bottom: var(--space-md);
}

.step-content {
    position: relative;
}

.step-title {
    font-family: var(--font-body);
    font-size: var(--text-lg);
    font-weight: 500;
    color: var(--color-text-primary);
    margin: 0 0 var(--space-sm);
}

.step-desc {
    font-family: var(--font-body);
    font-size: var(--text-sm);
    font-weight: 400;
    line-height: 1.6;
    color: var(--color-text-secondary);
    margin: 0;
}

/* -------------------------------------------------------------------
   CTA Cards Section
------------------------------------------------------------------- */
.work-cta-section {
    padding: var(--space-3xl) var(--side-padding);
    background-color: var(--color-bg);
}

.cta-cards-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(1rem, 2vw, 1.5rem);
    max-width: 1400px;
    margin: 0 auto;
}

.cta-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: clamp(1.5rem, 3vw, 2.5rem);
    border-radius: var(--radius-2xl);
    gap: var(--space-lg);
    opacity: 0;
    transform: translateY(30px);
}

.cta-card.animate-in {
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.6s var(--ease-smooth), transform 0.6s var(--ease-smooth);
}

.cta-card-pink {
    background-color: #FACDD4; /* Vibrant pink pastel */
}

.cta-card-blue {
    background-color: #BDE4FC; /* Vibrant sky blue pastel */
}

.cta-card-content {
    flex: 1;
}

.cta-card-title {
    font-family: var(--font-heading);
    font-size: clamp(1.25rem, 2vw, 1.5rem);
    font-weight: 400;
    line-height: 1.2;
    color: var(--color-text-primary);
    margin: 0 0 var(--space-sm);
}

.cta-card-desc {
    font-family: var(--font-body);
    font-size: var(--text-sm);
    font-weight: 400;
    line-height: 1.5;
    color: var(--color-text-secondary);
    margin: 0 0 var(--space-md);
}

.cta-card-link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-family: var(--font-body);
    font-size: var(--text-sm);
    font-weight: 500;
    color: var(--color-text-primary);
    text-decoration: none;
    padding: 0.5rem 1rem;
    border: 1px solid var(--color-text-primary);
    border-radius: var(--radius-md);
    transition: background 0.3s var(--ease-smooth), transform 0.3s var(--ease-smooth);
}

.cta-card-link:hover {
    background: rgba(0, 0, 0, 0.05);
    transform: translateX(4px);
}

.cta-card-link svg {
    transition: transform 0.3s var(--ease-smooth);
}

.cta-card-link:hover svg {
    transform: translate(2px, -2px);
}

.cta-card-visual {
    flex-shrink: 0;
}

.cta-placeholder {
    width: clamp(80px, 10vw, 120px);
    height: clamp(100px, 12vw, 140px);
    background: #fff;
    border-radius: var(--radius-lg);
}

/* Compact variant - no visual, reduced padding */
.cta-card--compact {
    padding: clamp(1.25rem, 2.5vw, 2rem);
}

.cta-card--compact .cta-card-content {
    flex: 1;
    max-width: 100%;
}

/* -------------------------------------------------------------------
   Responsive Styles
------------------------------------------------------------------- */
@media (max-width: 1200px) {
    .bento-stack {
        width: 280px;
    }
}

@media (max-width: 1024px) {
    .bento-grid {
        flex-direction: column;
        gap: 20px;
    }

    .bento-stack {
        width: 100%;
        flex-direction: row;
        gap: 12px;
    }

    .bento-small {
        flex: 1;
    }

    /* Stats responsive */
    .work-stats-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--space-lg);
    }

    /* Deliver responsive */
    .deliver-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    /* Process responsive */
    .process-timeline {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .work-header-section {
        padding-top: calc(80px + var(--space-2xl));
    }

    .bento-grid {
        flex-direction: column;
        gap: 16px;
    }

    .bento-featured {
        padding: 12px;
    }

    .bento-featured .bento-image-box {
        margin-bottom: 12px;
    }

    .bento-card-title {
        font-size: 22px;
    }

    .bento-tag {
        font-size: 12px;
        padding: 8px 12px;
    }

    .bento-stack {
        flex-direction: column;
        width: 100%;
        gap: 12px;
    }

    .bento-small {
        padding: 12px;
    }

    .bento-card-title-small {
        font-size: 14px;
    }

    /* Stats mobile */
    .work-stats-section {
        padding: var(--space-2xl) var(--side-padding);
    }

    .work-stats-grid {
        grid-template-columns: 1fr 1fr;
        gap: var(--space-md);
    }

    .work-stat {
        padding: var(--space-md);
    }

    .stat-number {
        font-size: clamp(1.5rem, 3vw, 2rem);
    }

    /* Deliver mobile */
    .work-deliver-section {
        padding: var(--space-2xl) var(--side-padding);
    }

    .deliver-grid {
        grid-template-columns: 1fr;
        gap: var(--space-md);
    }

    .deliver-card {
        padding: var(--space-lg);
    }

    /* Process mobile */
    .work-process-section {
        padding: var(--space-2xl) var(--side-padding);
    }

    .process-timeline {
        grid-template-columns: 1fr;
        gap: var(--space-md);
    }

    .process-step {
        padding: var(--space-md);
    }

    .step-number {
        font-size: clamp(2.5rem, 5vw, 3.5rem);
    }

    /* CTA mobile */
    .cta-cards-row {
        grid-template-columns: 1fr;
    }

    .cta-card {
        flex-direction: column;
        text-align: center;
    }

    .cta-card-visual {
        order: -1;
    }

    .cta-placeholder {
        width: 100px;
        height: 80px;
    }
}

/* -------------------------------------------------------------------
   Reduced Motion
------------------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
    .work-page-title,
    .work-page-subtitle,
    .bento-card,
    .bento-featured,
    .bento-small,
    .cta-card,
    .deliver-card,
    .process-step,
    .work-stat {
        opacity: 1;
        transform: none;
        transition: none;
    }

    .bento-card:hover,
    .bento-featured:hover .bento-image-box img,
    .bento-small:hover .bento-image-box-small img,
    .deliver-card:hover {
        transform: none;
    }
}

/* -------------------------------------------------------------------
   Animation States for New Sections
------------------------------------------------------------------- */
.work-stat,
.deliver-card,
.process-step {
    opacity: 0;
    transform: translateY(30px);
}

.work-stat.animate-in,
.deliver-card.animate-in,
.process-step.animate-in {
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.6s var(--ease-smooth), transform 0.6s var(--ease-smooth);
}
