/* ======================== Web Design Component Styles ======================== */

.pi-wrapper {
    background: transparent;
}

.pi-container {
    display: grid;
    grid-template-columns: 1fr 1.5fr;
    gap: 4rem;
    align-items: center;
}

/* 1. Image Wrapper */
.pi-image-column {
    position: relative;
    max-width: 450px;
    width: 100%;
}

.wd-image-wrapper {
    position: relative;
    border-radius: 0;
    overflow: visible;
}

.wd-image-wrapper img {
    width: 100%;
    border-radius: 0;
    border: 1px solid var(--border-color);
    display: block;
    filter: drop-shadow(0 20px 40px rgba(0, 0, 0, 0.3));
    z-index: 1;
    position: relative;
}

/* Accent glow behind photo in dark mode */
[data-theme="dark"] .wd-image-wrapper::before {
    content: '';
    position: absolute;
    inset: -15px;
    border-radius: 0;
    background: radial-gradient(ellipse at 30% 70%,
            rgba(5, 108, 202, 0.15),
            transparent 65%);
    z-index: -1;
    pointer-events: none;
}

/* 2. Floating Badge */
.wd-floating-badge {
    position: absolute;
    top: -12px;
    right: 1rem;
    background: var(--pure-white);
    border: 1px solid var(--border-color);
    border-radius: 0;
    padding: 0.45rem 1rem;
    font-size: 0.75rem;
    /* Slightly larger */
    font-family: var(--font-mono);
    color: var(--text-blue);
    display: flex;
    align-items: center;
    gap: 0.4rem;
    z-index: 3;
    box-shadow: var(--box-shadow);
}

.wd-badge-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #22c55e;
    box-shadow: 0 0 6px rgba(34, 197, 94, 0.6);
    flex-shrink: 0;
}

/* 3. Info Card Bottom */
.wd-card-bottom {
    position: absolute;
    bottom: 1.25rem;
    left: 1.25rem;
    right: 1.25rem;
    background: var(--pure-white);
    /* Pure white */
    border: 1px solid var(--border-color);
    border-left: 3px solid var(--accent-color2);
    border-radius: 0;
    padding: 1rem 1.25rem;
    /* Slightly more padding */
    display: flex;
    align-items: center;
    justify-content: space-between;
    z-index: 2;
    box-shadow: none;
    /* Removed shadow per request */
    backdrop-filter: none;
    /* Removed blur per request */
}

[data-theme="dark"] .wd-card-bottom {
    background: var(--pure-white);
    /* Keep pure white or should it adapt? User said "pure-white", but "dark/light toggle should work". Usually implies keeping visibility. I'll make it slightly off-white in dark mode or keep pure white if they persist. Let's try pure white first. */
    color: var(--text-color);
    /* Ensure text is readable on white in dark mode */
}

/* If user wants it to adapt to dark theme while staying "clean" */
/* [data-theme="dark"] .wd-card-bottom { background: var(--card-bg); } */

.wd-name {
    font-weight: 600;
    font-size: var(--font-p-body);
    /* Slightly larger */
    color: var(--text-color);
    /* High contrast for white bg */
    display: block;
}

.wd-role {
    font-size: 0.8rem;
    /* Slightly larger */
    display: block;
    font-family: var(--font-mono);
    color: var(--accent-color2);
    opacity: 0.9;
}

.wd-linkedin-link {
    color: #0077b5;
    /* LinkedIn Blue */
    display: flex;
    align-items: center;
    transition: transform 0.2s ease;
}

.wd-linkedin-link:hover {
    transform: scale(1.1);
}


/* 4. Content Area */
.pi-content-area {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.pi-intro-text {
    font-size: var(--font-p-medium);
    margin-bottom: 1rem;
}

/* 5. Terminal Feature Grid */
.pi-feature-list,
.pi-feature-list * {
    font-family: var(--font-mono) !important;
}

.pi-feature-list p,
.pi-feature-list .pi-feat-card-desc {
    color: var(--text-color) !important;
}

.pi-feature-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.25rem;
    margin-bottom: 2rem;
}

.pi-feat-card {
    position: relative;
    background: #ffffff;
    border: 1px solid var(--border-color);
    border-radius: 0;
    box-shadow: var(--box-shadow);
    display: flex;
    flex-direction: column;
    cursor: pointer;
    transition: all 0.3s ease;
}

[data-theme="dark"] .pi-feat-card {
    background: var(--card-bg);
}

.pi-feat-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--box-shadow-hover, 0 8px 32px rgba(5, 108, 202, 0.14));
}

/* Permanent Border Gradients */
.pi-feat-card--js {
    border-image-source: linear-gradient(to bottom, #f59e0b, transparent);
    border-image-slice: 1;
}

.pi-feat-card--config {
    border-image-source: linear-gradient(to bottom, #3b82f6, transparent);
    border-image-slice: 1;
}

.pi-feat-card--ts {
    border-image-source: linear-gradient(to bottom, #10b981, transparent);
    border-image-slice: 1;
}

.pi-feat-card--json {
    border-image-source: linear-gradient(to bottom, #a78bfa, transparent);
    border-image-slice: 1;
}

.pi-feat-card-tab {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    padding: 0.75rem 1.25rem;
    background: #dde6f2;
    border-bottom: 1px solid var(--border-color);
    border-radius: 0;
}

[data-theme="dark"] .pi-feat-card-tab {
    background: var(--secondary-color);
}

.pi-feat-tab-filename {
    font-size: 0.85rem;
    color: var(--text-blue);
    font-family: var(--font-mono);
    opacity: 0.8;
}

.pi-feat-card-body {
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
    flex: 1;
}

.pi-feat-card-title {
    font-family: var(--font-mono);
    font-size: var(--font-p-heading3);
    font-weight: 600;
    margin: 0;
    transition: color 0.3s ease;
}

.pi-feat-card-desc {
    font-size: 0.85rem;
    color: var(--text-color-light2);
    line-height: 1.55;
    margin: 0;
}

/* Variant Accents */
.pi-feat-card--js .pi-feat-card-title {
    color: #f59e0b;
}

.pi-feat-card--config .pi-feat-card-title {
    color: #3b82f6;
}

.pi-feat-card--ts .pi-feat-card-title {
    color: #10b981;
}

.pi-feat-card--json .pi-feat-card-title {
    color: #a78bfa;
}

/* 6. CTA Area */
.pi-cta-area {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    align-items: flex-start;
}

.pi-trust-line {
    display: flex;
    gap: 1.5rem;
    font-size: 0.8rem;
    color: var(--text-color-light2);
}

.pi-trust-line span {
    display: flex;
    align-items: center;
    gap: 0.35rem;
}

/* 7. Responsive */
@media screen and (max-width: 1024px) {
    .pi-container {
        grid-template-columns: 1fr;
        gap: 3rem;
    }

    .pi-image-column {
        margin: 0 auto;
    }

    .pi-content-area {
        text-align: center;
        gap: 0;
    }

    .pi-cta-area {
        align-items: center;
    }
}

@media screen and (max-width: 768px) {
    .pi-feature-list {
        grid-template-columns: 1fr;
    }

    .pi-trust-line {
        flex-direction: column;
        gap: 0.5rem;
    }
}